JAVA面试习题梳理-P3

0.力扣:https://leetcode-cn.com/

p3_力扣.png

1.String.intern()
p3_InternTest.png

2.可重入锁:一个线程中的多个流程可以获取同一把锁,持有这把同步锁可以再次进入,自己可以获取自己的内部锁(暂时模糊理解下)
p3_可重入锁_synchronized.png

p3_可重入锁_reentrantlock.png

3.基于Synchronized和ReentrantLock可重入锁局限性分析
p3_可重入锁_synchronized局限性.png

p3_可重入锁_reentrantlock局限性.png

4.LockSupport
LockSupport的park()和unpark()方法底层调用unsafe类的park和unpark方法,分别使当前线程的许可证permit设置为0和1,注意多次调用upark不会使permit累加,即permit最大是1
p3_lockSupport.png

5.AQS
定义:抽象的队列同步器
基于ReentrantLock对AQS的源码深度解读
ReentrantLock里有属性Sync,Sync继承自AQS,架构如下
p3_lock_AQS架构.png

AQS是所有关于锁的实现机制的上层建筑(顶层设计),有一个子类sync,并通过cas控制state控制锁的开放和关闭,把没有抢到cpu时间片的线程加到内部类node队列(CLH队列)里,实现机制类比map
image.png

image.png

AQS这个类的内部类node的属性说明
image.png

image.png

AQS源码分析
image.png

image.png

image.png

6.spring4和5的aop顺序
spring45_aop顺序.png

7.Spring循环依赖
定义:多个bean之间的相互依赖,形成了一个闭环,比如A依赖B,B依赖C,C依赖A
通常来说,如果问Spring容器内部如何解决循环依赖,一定默认指的是单例Bean中,属性相互引用的场景,即scop只能是singleton不能是prototype,否则报错
p3_循环依赖.png

p3_循环依赖_test.png

对构造方法注入的Bean不能解决,setter注入的方式可以
8.DefaultSingletonBeanRegistry的三级缓存,解决循环依赖问题
p3_循环依赖_三级缓存代码.png

p3_循环依赖_三级缓存代码说明.png

p3_循环依赖_三级缓存流程.png

p3_循环依赖_三级缓存流程2.png

p3_循环依赖_三级缓存流程_getSingleton.png

p3_循环依赖_三级缓存流程3.png

9.redis
查看版本 redis-server -v 或者登录后 info
登录状态下的帮助命令 help @数据类型
redis的命令不区分大小写,但是key区分大小写
linux的redis版本稳定的6.0.8
10.数据类型
p3_redis数据类型.png

String
p3_redis数据类型_string.png

Hash
p3_redis数据类型_hash.png

list
p3_redis数据类型_list.png

Set
p3_redis数据类型_set.png

p3_redis数据类型_set_抽奖.png

p3_redis数据类型_set_点赞.png

p3_redis数据类型_set_共同关注的人.png

p3_redis数据类型_set_可能认识的人.png

Zset
p3_redis数据类型_zset.png

![p3_redis数据类型_zset_热搜.png](https://upload-images.jianshu.io/upload_images/10798990-d66db4a1cded72cd.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

11.基于redis实现的分布式锁(上传原因,倒叙展示)
p3_killLunch10.png

p3_killLunch9.png

p3_killLunch8.png

p3_killLunch7.png

p3_killLunch6.png

p3_killLunch5.png

p3_killLunch4.png

p3_killLunch3.png

p3_killLunch2.png

p3_killLunch1.png

p3_RedisConfig.png

p3_RedisUtils.png

12.redis占用内存不设置或者设置为0,在64位操作系统下不限制内存大小,在32位操作系统下3G,一般生产配置为物理内存的四分之三
修改redis占用内存:修改配置文件maxmemory或者通过命令config set maxmemory 100*1024,单位字节
查看redis配置,config get xxxx
查看redis全部信息,info
查看redis内存(配置和使用)信息,info memory
如果redis内存打满,报错oom
13.redis缓存删除策略:
1.定时删除:过期时间一到就删除。优点是数据的实时性很高,缺点是cpu需要时刻监督redis数据的过期时间,cpu很忙
2.惰性删除:如果未过期返回数据,发现已过期,删除,返回不存在。优点是相对前者降低了cpu的压力,缺点是对内存不友好,有可能把已经过期的数据还存在redis里占用内存
3.定期删除:
image.png

14.redis缓存淘汰策略


p3_Redis内存淘汰策略.png

,生产建议配置allkeys-lru
15.LRU算法(最近最少使用),核心是哈希链表


p3_LRU_node.png

p3_LRU_DoubleLinkedStructure.png

p3_LRU.png

p3_LRU_Test.png

你可能感兴趣的:(JAVA面试习题梳理-P3)