java同步锁
⑴ java中的同步锁synchronized有哪几种
有4种:
instance 方法同步、
instance 方法中部分程式码同步、
static 方法同步、
class literals 同步。
⑵ java中哪种同步锁比较好用
synchronized用法简单,同步方法或者同步块,但是比较重量级。
lock用起来稍麻烦,API层面的同步,竞争激烈性能比synchronized好很多。
Atomic性能比synchronized略逊,而激烈的时候,也能维持常态,但是只能同步一个值。
volatile轻量级强制读取内存, 禁止指令重排,特定场合使用,不是万能的同步,理解原理分析后才能使用。
⑶ java线程中的同步锁和互斥锁有什么区别
互斥是通过竞争对资源的独占使用,彼此之间不需要知道对方的存在,执行顺序是一个乱序。
同步是协调多个相互关联线程合作完成任务,彼此之间知道对方存在,执行顺序往往是有序的。
⑷ java 程序中怎么保证多线程的运行安全
2.1.读一致性
Java 中针对上述“读不安全”的问题提供了关键字 volatile 来解决问题,被 volatile 修饰的成员变量,在内容发生更改的时候,会通知所有线程去主内存更新最新的值,这样就解决了读不安全的问题,实现了读一致性。
但是,读一致性是无法解决写一致性的,虽然能够使得每个线程都能及时获取到最新的值,但是1.1中的写一致性问题还是会存在。
既然如此,Java 为啥还要提供 volatile 关键字呢?这并非多余的存在,在某些场景下只需要读一致性的话,这个关键字就能够满足需求而且性能相对还不错,因为其他的能够保证“读写”都一直的办法,多多少少存在一些牺牲。
2.2.写一致性
Java 提供了三种方式来保证读写一致性,分别是互斥锁、自旋锁、线程隔离。
2.2.1.互斥锁
互斥锁只是一个锁概念,在其他场景也叫做独占锁、悲观锁等,其实就是一个意思。它是指线程之间是互斥的,某一个线程获取了某个资源的锁,那么其他线程就只能睡眠等待。
在 Java 中互斥锁的实现一般叫做同步线程锁,关键字 synchronized,它锁住的范围是它修饰的作用域,锁住的对象是:当前对象(对象锁)或类的全部对象(类锁)——锁释放前,其他线程必将阻塞,保证锁住范围内的操作是原子性的,而且读取的数据不存在一致性问题。
对象锁:当它修饰方法、代码块时,将会锁住当前对象
类锁:修饰类、静态方法时,则是锁住类的所有对象
注意:锁住的永远是对象,锁住的范围永远是 synchronized 关键字后面的花括号划定的代码域。
2.2.2.自旋锁
自旋锁也只是一个锁概念,在其他场景也叫做乐观锁等。
自旋锁本质上是不加锁,而是通过对比旧数据来决定是否更新:
⑸ JAVA编程同步,加锁如何实现,有何优缺点
同步锁“synchronize”,手动锁Lock
synchronize:自动锁住,自动开锁。(自动都是建立在一定的条件上的)
Lock:手动,手动锁住,手动开锁
具体如何实现,这里不好说,一时说不清,自行搜索。