温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

java线程相关知识点有哪些

发布时间:2021-11-24 15:28:19 来源:亿速云 阅读:189 作者:iii 栏目:大数据

这篇文章主要讲解了“java线程相关知识点有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java线程相关知识点有哪些”吧!

cas compare and swap(exchange):

  1. 读取当前值

  2. 计算结果值

  3. 比较当前值和内存值

  4. 更新新值

  5. ABA问题,增加额外字段

  6. 底层原语 lock(硬件锁信号) cmpxchg

java对象内存布局

对象头(markword ,class point,在64位系统上jvm开启压缩为4字节,不开启为8字节),(数组长度-4字节) 实例数据,对齐(按系统总线位数补齐提高效率),见下图 java线程相关知识点有哪些

锁升(降)级过程

new->偏向锁->轻量级锁(无锁,自旋锁,自适应自旋锁)->重量级锁

  1. 偏向锁(默认延迟4秒加)->在对象的markword中添加指向锁对象的指针

  2. 轻量级锁->竞争线程用cas的方式竞争指向锁对象

  3. 重量级锁->用户态向内核态申请系统锁,申请到以后其他竞争线程全部处于队列状态(降低资源消耗)

  4. 锁降级:一般发生在gc的情况下,所以这时候降级失去意义

  5. 锁消除:引用不会被其他线程调用时,隐性消除内部锁

  6. 锁粗化:对一组对象相同的操作,值加锁最外层操作(如 while(i<100) {...})

  7. 超线程:一组ALU,2组registers+pc

synchronized 实现过程

  1. 代码层:synchronized

  2. 源码monitorenter monitorexit

  3. 锁升级

  4. lock cmpxchg

缓存行对齐

在程序读取数据的时候是按块来读取提高效率(64字节,根据cpu)
CPU 1,2级缓存属于核,3级缓存共享
java线程相关知识点有哪些

volatile关键字作用

  1. 线程可见性

  2. 禁止代码重排,如下描述

  • 内存屏障 保证语句顺序执行,最底层依然是lock

  • 写写屏障 volatile 写操作 写读屏障

  • 读读屏障 volatile 读操作 读写屏障

强软弱虚引用
  • 强引用: Object o = new Object();

  • 软引用: SoftReference<Object> softReference = new SoftReference<>(new Object()); 堆空间不够时会被回收,适用于缓存

  • 弱引用: WeakReference<Object> weakReference = new WeakReference<>(new Object()); 只要gc就会被回收,适用一次使用,缓存之类 ThreadLocal.entry使用的弱引用,使用ThreadLocal 时,须调用一次ThreadLocal.remove释放其中的map的值,因为回收ThreadLocal时只回收key,entry不会被回收

  • 虚引用: PhantomReference<Object> phantomReference = new PhantomReference(new Object(),new ReferenceQueue()); 管理堆外内存,比如nio,zero copy

感谢各位的阅读,以上就是“java线程相关知识点有哪些”的内容了,经过本文的学习后,相信大家对java线程相关知识点有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI