volatile、Synchonized、Lock比较浅析

众所周知,在多线程并发编程过程中synchronizedvolatile用的很多,它们两个都是java中的关键字,都可以看做锁,可以把volatile看做轻量级的synchronized,那么具体的它们两个有什么差别呢?同样,java1.5之后引入了Lock接口,可以通过Lock实现多种锁,它们之间又有什么区别呢?
首先看一下volatile,先看一下volatile的定义:Java编程语言允许线程访问共享变量,为了确保共享变量能被准确和一致的更新,线程应该确保通过排他锁单独获得这个变量。通过volatile可以保证对单个变量的读/写具有原子性,可以把对volatile变量的单个读/写,看做使用同一个锁对这个读写操作做了同步,注意是单个,volatile并不能保证复合操作的原子性,即使如volatile++。volatile可以保证共享变量之间的可见性,可以理解为对一个volatile的读,总是在任意线程对这个volatile变量写入之后。
再看一下synchronized,java中每个对象都可以作为锁,synchronized可以通过三种形式实现锁:1、修饰普通方法,此时锁是当前实例对象;2、修饰静态同步方法,锁是当前类的Class对象;3、修饰同步方法块,锁是Syschronized括号里的对象。synchronized实现的原理是通过monitorenter和monitorexit两个指令来实现的,并且JVM会保证这两个指令配对出现。当线程执行到monitorenter时,便会开始尝试获得对象的锁,获得之后,其他对象将无法获得此对象的锁,当执行到monitorexit指令时,便会开始释放对象的锁。synchronized可以通过整个临界区的互斥性保证对整个临界区代码的执行具有原子性。Syschronized用的锁存在于对象头中,其中对象头的Mark Word存储着hashcode和锁信息,可以实现三种锁:偏向锁、轻量级锁、重量级锁。synchronized支持重入,比如递归时执行线程能连续多次的获取该锁,因此其具有重入性
Jdk 1.5在并发包中加入了Lock接口及相关实现类,它提供了和synchronized相似的同步功能,使用synchronized会隐式的获得锁,但是锁的获取和释放是固定的,而通过Lock可以显示的获取和释放锁,如此一来拓展性和灵活性得到了增强,同时Lock接口还提供了一些synchronized不具备的特性,比如尝试非阻塞的获取锁,能被中断地获取锁,超时的获取锁。Lock有个实现叫做ReentranLock,顾名思义,支持重入,虽然不像synchronized支持隐式的重入,但是在已经获得该锁的线程再次调用lock()方法而不被阻塞。
由于锁在并发编程中应用频繁,在功能上,锁会比volatile更强大,而在可伸缩性和执行性能上,volatile更有优势,但是在使用时要根据具体情况进行合理正确的使用。
第一次写博客,将所学所想所积累所实践以博客的形式写出来,坚持,成为一种习惯!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值