Java实现线程同步的四种方式总结_第1页
Java实现线程同步的四种方式总结_第2页
Java实现线程同步的四种方式总结_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第Java实现线程同步的四种方式总结}

如果你还想深入了解Synchronized的底层原理,可以看Synchronized的实现原理详解(看这篇就够了)

2.使用ReentrantLock

ReentrantLock类是可重入、互斥、实现了Lock接口的锁,它与使用synchronized方法具有相同的基本行为和语义,并且扩展了其能力。

privateintaccount=100;

//需要声明这个锁

privateLocklock=newReentrantLock();

publicintgetAccount(){

returnaccount;

//这里不再需要synchronized

publicvoidsave(intmoney){

lock.lock();

try{

account+=money;

}finally{

lock.unlock();

synchronized与Lock的对比

ReentrantLock是显示锁,手动开启和关闭锁,别忘记关闭锁;

synchronized是隐式锁,出了作用域自动释放;

ReentrantLock只有代码块锁,synchronized有代码块锁和方法锁;

使用ReentrantLock锁,JVM将花费较少的时间来调度线程,线程更好,并且具有更好的扩展性(提供更多的子类);

优先使用顺序:

ReentrantLocksynchronized同步代码块synchronized同步方法

3.使用原子变量实现线程同步

为了完成线程同步,我们将使用原子变量(Atomic***开头的)来实现。

比如典型代表:AtomicInteger类存在于java.util.concurrent.atomic中,该类表示支持原子操作的整数,采用getAndIncrement方法以原子方法将当前的值递加。

具体示例如下:

privateAtomicIntegeraccount=newAtomicInteger(100);

publicAtomicIntegergetAccount(){

returnaccount;

publicvoidsave(intmoney){

account.addAndGet(money);

}

4.ThreadLocal实现线程同步

如果使用ThreadLocal管理变量,则每一个使用该变量的线程都获得该变量的副本,副本之间相互独立,这样每一个线程都可以随意修改自己的变量副本,而不会对其他线程产生影响,从而实现线程同步。

具体代码示例如下:

//只改Bank类,其余代码与上同

publicclassBank{

//创建一个线程本地变量ThreadLocal

privatestaticThreadLocalIntegeraccount=newThreadLocalInteger(){

@Override

//返回当前线程的"初始值"

protectedIntegerinitialValue(){

return100;

publicvoidsave(intmoney){

//设置线程副本中的值

account.set(account.get()

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论