美文网首页
JAVA面试习题梳理-P3

JAVA面试习题梳理-P3

作者: ___Kevin | 来源:发表于2021-03-12 18:45 被阅读0次

    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
    此处需要自行实际走源码理解下,重点
    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.三级缓存
    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://img.haomeiwen.com/i10798990/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.定期删除:。。。
    14.redis缓存淘汰策略
    p3_Redis内存淘汰策略.png
    15.LRU算法
    p3_LRU_node.png
    p3_LRU_DoubleLinkedStructure.png
    p3_LRU.png
    p3_LRU_Test.png

    相关文章

      网友评论

          本文标题:JAVA面试习题梳理-P3

          本文链接:https://www.haomeiwen.com/subject/zulmfltx.html