Java多线程
wangyuanjun008
天亮了!
展开
-
乐观锁与悲观锁
乐观锁 乐观锁(Optimistic Lock), 顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。乐观锁适用于多读的应用类型,这样可以提高吞吐量,像数据库如果提供类似于write_condition机制的其实都是提供的乐观锁。 CAS便是乐观锁技术,当多个线程尝试使用CAS同时...转载 2018-05-13 15:00:17 · 228 阅读 · 0 评论 -
Java多线程系列——原子类的实现(CAS算法)
Java提供的原子类是靠 sun 基于 CAS 实现的,CAS 是一种乐观锁。关于乐观锁与悲观锁。 原子变量类相当于一种泛化的 volatile 变量,能够支持原子的和有条件的读-改-写操作。AtomicInteger 表示一个int类型的值,并提供了 get 和 set 方法,这些 Volatile 类型的int变量在读取和写入上有着相同的内存语义。它还提供了一个原子的 compare...转载 2018-05-13 15:02:01 · 380 阅读 · 0 评论 -
Java多线程系列——volatile关键字
一:volatite 简述Java 语言提供了一种稍弱的同步机制,即 volatile 变量.用来确保将变量的更新操作通知到其他线程,保证了新值能立即同步到主内存,以及每次使用前立即从主内存刷新. 当把变量声明为volatile类型后,编译器与运行时都会注意到这个变量是共享的.在多处理器的CPU架构下,因为每个处理器都有自己的缓存,线程访问变量的时候会读取缓存,多个线程读取的缓存不一样会导...转载 2018-06-11 10:36:56 · 454 阅读 · 0 评论 -
Java多线程系列——Lock类解析
JVM提供了synchronized关键字来实现对变量的同步访问以及用wait和notify来实现线程间通信。在jdk1.5以后,JAVA提供了Lock类来实现和synchronized一样的功能,并且还提供了Condition来显示线程间通信。一:Lock类探讨一下java.util.concurrent.locks包中常用的类和接口。1.lock首先要说明的就是Lock...原创 2018-06-11 10:38:51 · 490 阅读 · 0 评论 -
Java多线程系列——死锁
一、死锁讲解在Java中使用多线程,就会有可能导致死锁问题。死锁会让程序一直卡住,不再程序往下执行。我们只能通过中止并重启的方式来让程序重新执行。这是我们非常不愿意看到的一种现象,我们要尽可能避免死锁的情况发生! 造成死锁的原因可以概括成三句话:当前线程拥有其他线程需要的资源当前线程等待其他线程已拥有的资源都不放弃自己拥有的资源1.1锁顺序死锁首先我们来看一下最简...转载 2018-07-24 21:58:29 · 515 阅读 · 0 评论