1.String.intern()
2.可重入锁:一个线程中的多个流程可以获取同一把锁,持有这把同步锁可以再次进入,自己可以获取自己的内部锁(暂时模糊理解下)
3.基于Synchronized和ReentrantLock可重入锁局限性分析
4.LockSupport
LockSupport的park()和unpark()方法底层调用unsafe类的park和unpark方法,分别使当前线程的许可证permit设置为0和1,注意多次调用upark不会使permit累加,即permit最大是1
5.AQS
定义:抽象的队列同步器
基于ReentrantLock对AQS的源码深度解读
ReentrantLock里有属性Sync,Sync继承自AQS,架构如下
AQS是所有关于锁的实现机制的上层建筑(顶层设计),有一个子类sync,并通过cas控制state控制锁的开放和关闭,把没有抢到cpu时间片的线程加到内部类node队列(CLH队列)里,实现机制类比map
AQS这个类的内部类node的属性说明
AQS源码分析
6.spring4和5的aop顺序
7.Spring循环依赖
定义:多个bean之间的相互依赖,形成了一个闭环,比如A依赖B,B依赖C,C依赖A
通常来说,如果问Spring容器内部如何解决循环依赖,一定默认指的是单例Bean中,属性相互引用的场景,即scop只能是singleton不能是prototype,否则报错
对构造方法注入的Bean不能解决,setter注入的方式可以
8.DefaultSingletonBeanRegistry的三级缓存,解决循环依赖问题
9.redis
查看版本 redis-server -v 或者登录后 info
登录状态下的帮助命令 help @数据类型
redis的命令不区分大小写,但是key区分大小写
linux的redis版本稳定的6.0.8
10.数据类型
String
Hash
list
Set
Zset
11.基于redis实现的分布式锁(上传原因,倒叙展示)
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.定期删除:
14.redis缓存淘汰策略
,生产建议配置allkeys-lru
15.LRU算法(最近最少使用),核心是哈希链表