Java 线程同步

1.Synchronized

Java提供关键字synchronized来防止资源冲突。当任务要执行被synchronized关键字保护的代码片段时,它将检查锁是否可用,然后获取锁,执行代码,释放锁。

如果一个任务处于一个对标记为synchronized的方法的调用中,那么在这个线程从该方法返回之前,其他所有要调用类中标记为synchronized方法的线程都会被阻塞。

2.Lock

Lock对象必须被显式的创建锁定和释放

Lock lock = new ReentrantLock();

lock.unlock();

3.volatile

a:volatile关键字为域变量的访问提供了一种免锁机制,

b:使用volatile修饰域相当于告诉虚拟机该域可能会被其他线程更新,

c:因此每次使用该域就要重新计算,而不是使用寄存器中的值

d:volatile不会提供任何原子操作,它也不能用来修饰final类型的变量

5:使用局部变量实现线程同步

如果使用ThreadLocal管理变量,则每一个使用该变量的线程都获得该变量的副本,

副本之间相互独立,这样每一个线程都可以随意修改自己的变量副本,而不会对其他线程产生影响。

ThreadLocal() : 创建一个线程本地变量

get() : 返回此线程局部变量的当前线程副本中的值

initialValue() : 返回此线程局部变量的当前线程的"初始值"

set(T value) : 将此线程局部变量的当前线程副本中的值设置为value


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

原子操作就是指将读取变量值、修改变量值、保存变量值看成一个整体来操作

即-这几种行为要么同时完成,要么都不完成。

在java的util.concurrent.atomic包中提供了创建了原子类型变量的工具类

使用该类可以简化线程同步。

其中AtomicInteger表可以用原子方式更新int的值,可用在应用程序中(如以原子方式增加的计数器),

但不能用于替换Integer;可扩展Number,允许那些处理机遇数字类的工具和实用工具进行统一访问。

AtomicInteger类常用方法:

AtomicInteger(int initialValue) : 创建具有给定初始值的新的AtomicInteger

addAddGet(int dalta) : 以原子方式将给定值与当前值相加

get() : 获取当前值

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

推荐阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,391评论 11 349
  • Java8张图 11、字符串不变性 12、equals()方法、hashCode()方法的区别 13、...
    Miley_MOJIE阅读 3,757评论 0 11
  • Java-Review-Note——4.多线程 标签: JavaStudy PS:本来是分开三篇的,后来想想还是整...
    coder_pig阅读 1,691评论 2 17
  • 诗一首——游玉门关和汉长城 诗一首——游玉门关和汉长城 6月13日游玉门关和汉长城感慨万千特赋诗一首以抒情怀。 长...
    琳琳爹阅读 684评论 0 1
  • 我所有的工作都是在58同城上投简历、去应聘而找到的,而所有的职位都是奔着淘宝系去的。应聘的时候,也是穿得很随便,傻...
    纠偏人阅读 217评论 5 2