Java之同步

请尊重博主劳动成果,转载请标明出处。

volatile

使用volatile对属性字段做同步时,必须保证对该属性的操作是原子性的。如果有非原子性的操作,则volatile可能会无效。

Java并发编程:volatile关键字解析
http://www.cnblogs.com/dolphin0520/p/3920373.html
这一篇博客对volatile讲解的很详细,值得仔细阅读。

synchronized,wait,notify与notifyAll

synchronized可用在代码块和方法上。

class T{
    public synchronized static void method(){
        ....
    }
}
或
class T{
    public void method(){
        synchronized(T.class){
            ...
        }
    }
}
或
class T{
    private static byte[] lock = new byte[0];
    public void method(){
        synchronized(lock){
            ...
        }
    }
}

如果是以上三种方式,则是对T这个类加锁,T类型的所有对象竞争的是同一个锁。

class T{
    public synchronized void method(){
        ....
    }
}
或
class T{
    private byte[] lock = new byte[0];
    public void method(){
        synchronized(lock){
            ...
        }
    }
}

如果是以上两种方式,则是对T类型的对象加锁,锁只对同一个对象有效。

更详细的讲解,请查看博客:Java中Synchronized的用法这篇博客。

wait()方法只能在synchronized内使用,调用此方法会让对象释放持有的锁,并加入等待池。notify()方法会从等待池任意唤醒一个对象,待执行完synchronized代码,这个被唤醒的对象便能够获取到锁。notityAll()方法会唤醒等待池中所有的对象,这些被唤醒的对象进入锁池竞争锁。

锁池:线程A获取到锁,紧接着来了B,C,D三个线程。因为A持有锁,所以B,C,D就进入这个锁的锁池,等待A释放锁。
等待池:进入synchronized代码中的线程A调用了wait()方法,则A释放锁进入该对象等待池,等待被唤醒。

更详细的内容请阅读博客
java中的锁池和等待池线程间协作:wait、notify、notifyAll

单例模式

双重检测:

public class T{
    private volatile static T instance;
    private T(){}

    public static T getInstance(){
        if(instance == null){
            synchronized(T.class){
                if(instance == null){
                    instance = new T();
                }
            }
        }
        return instance;
    }
}

另一种更简洁的方式:

public class T{
    private static class Holder{
        static T instance = new T();
    }

    public static void getInstance(){
        return Holder.instance;
    }
}

参考了Java 中的双重检查(Double-Check)Initialization-on-demand holder idiom这两篇博客。

Lock

Java 并发开发:Lock 框架详解
http://www.cnblogs.com/aishangJava/p/6555291.html
这篇博客对Lock的知识讲解的非常详细,值得仔细阅读。

指令重排序

Java内存访问重排序的研究
https://tech.meituan.com/java-memory-reordering.html
如果有时间,可以细细阅读。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值