摘要: 保证线程安全演进: synchronized volatile AtomicInteger Lock接口提供的方法: void lock():加锁 void unlock():解锁 void lockInterruptibly():在多个线程并发获取锁的时候,那么,当有些线程拿不到锁时会等待,会不停 阅读全文
posted @ 2017-12-28 20:55 凌晨六点半 阅读(680) 评论(0) 推荐(0) 编辑
摘要: 原子更新基本类型 原子更新数组 原子更新抽象类型 原子更新字段 原子更新基本类型: 运行结果: 运行结果: 对CAS的源码理解:--初步理解 在AtomicInteger中有这样一段源码: 其中,compareAndSwap就是CAS的缩写。如果prev和next不相等,则返回true。否则,返回f 阅读全文
posted @ 2017-12-28 20:12 凌晨六点半 阅读(402) 评论(0) 推荐(0) 编辑
摘要: volatile:称之为轻量级锁,被volatile修饰的变量,在线程之间是可见的。 可见:一个线程修改了这个变量的值,在另一个线程中能够读取到这个修改后的值。 synchronized除了线程之间互斥之外,还有一个非常大的作用,就是保证可见性。以下demo即保证a值的可见性。 首先来看demo: 阅读全文
posted @ 2017-12-28 15:47 凌晨六点半 阅读(508) 评论(0) 推荐(0) 编辑
摘要: 运行结果: 控制台一直在运行,但是无任何输出。 通过命令检测是否真的发生了死锁: 点击线程,检测死锁: 阅读全文
posted @ 2017-12-28 13:52 凌晨六点半 阅读(151) 评论(0) 推荐(0) 编辑
摘要: 自旋锁,自己在不停的旋转,旋的是CPU的时间片,也就是空转CPU。当另外一个线程没有执行结束时,它一直在自旋等待。它会一直等待另外的线程执行完毕。 运行结果: 全部执行完毕Thread-0开始执行...Thread-1开始执行...Thread-1执行完毕了Thread-0执行完毕了 以上结果明显, 阅读全文
posted @ 2017-12-28 13:38 凌晨六点半 阅读(325) 评论(0) 推荐(0) 编辑
摘要: 运行结果: 以上结果说明,线程A在释放方法a的同步锁之前,是可以重新获得b方法的同步锁的。同一个线程拿到同一个对象的锁,它是可以进入另一个同步方法的,这就是锁的重入。以上代码仅仅是同一个线程在一个同步方法中去成功调用另一个同步方法,并且,锁的是同一个实例。那么,不同的线程拿同一把对象去加锁,会怎样进 阅读全文
posted @ 2017-12-28 12:01 凌晨六点半 阅读(382) 评论(0) 推荐(0) 编辑