java并发

static vs final
static 静态(类加载时(程序编译时)唯一初始化内存)
final 最终(不可变,对变量而言基本对象值不可改,对象引用不可改(对象内容可改))
把上面两个分别用来解决什么问题弄清楚就行,不必纠结。

线程安全
xx所用到的资源的生命周期在一个线程内,则xx是线程安全的。
不可变对象是安全的,引用不一定是安全的,引用一个不可变对象不一定是安全地。(查看是安全,修改不一定安全)

简单内存模型及对关键字 volatile 和 synchronized理解
堆(对象堆) 栈(线程栈)
局部变量和方法本地变量(也是局部变量)在线程中,
对象以及其 属性变量在堆中,
写回的时候就涉及到如何保持串行一致,
volatile是保持变量可见性,就是说一个属性变量(局部变量在非逃逸情况下(资源生命周期在线程内)是安全的)在线程中改变会回写到内存中,所有改变都是可见的,
但不能保证属性变量在不同线程中的副本是一致的,
synchronized是解决竞争问题的,同一时间只有一个线程可以进入代码块,退出时变量被刷回内存。

线程 wait() notify() notifyall() 可能存在信号丢失,假唤醒(很奇怪),必须在持有锁的代码块中

成员变量线程副本 threadlocal

资源竞争导致死锁,死锁可以用按顺序加锁,加锁超时回退,以及检测死锁算法并解扣方法解决。

并发编程中牢记小技巧
信号丢失:资源添加信号量特性
条件滑动:条件资源保持安全(同步)
管程锁死:线程调度编写中注意持有的锁是否复数,复数则检查

java并发数据结构
锁:重入(重入锁死),公平性(公平锁),读写锁(其准入区别)
信号量:Semaphore
阻塞队列:BlockingQueue
线程池:ThreadPool
CAS数据结构:Compare and swap
无阻塞算法及数据结构:ConcurrentLinkedQueue

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第1章 并发编程的挑战 1.1 上下文切换 即便是单核CPU也支持多线程并发,CPU通过给每个线程分配时间片(几十...
    卑鄙的鹿尤菌阅读 10,260评论 1 22
  • 一.线程安全性 线程安全是建立在对于对象状态访问操作进行管理,特别是对共享的与可变的状态的访问 解释下上面的话: ...
    黄大大吃不胖阅读 4,332评论 0 3
  • layout: posttitle: 《Java并发编程的艺术》笔记categories: Javaexcerpt...
    xiaogmail阅读 11,122评论 1 19
  • 本来想着写的别的,发现真的不知道写点什么好。刚好上周日跟大学同学在东直门聚了聚,还是有点感触的,拿出来也好。...
    算法成瘾者阅读 1,085评论 3 3
  • 真正困扰我的是,他捧出一颗真心给我,我不要,或者不敢要,不是我的,我不能要,不敢要,而且,脏,那些土,泥,太脏了,...
    兮兮AX阅读 2,490评论 0 0