标签:加锁 双重 校验 SingletonTest volatile singletonTest 单例 null
先上代码
public class SingletonTest { // 使用volatile保证可见性 private static volatile SingletonTest singletonTest = null; private SingletonTest() { } public static SingletonTest getInstance() { //第一重校验 if (singletonTest == null) { // 加锁 synchronized (SingletonTest.class) { // 第二重校验 if (singletonTest == null) { singletonTest = new SingletonTest(); } } } return singletonTest; } }
这里面有2个关键点
1.使用volatile保证可见性
volatile功能:当一个共享变量被volatile修饰时,它会保证修改的值会立即被更新到主存,当有其他线程需要读取时,它会去内存中读取新值
2.使用双重校验
这里为一直无法理解,为什么要加双重校验锁,我原本以为理论上,只要在synchronized里面加一层校验锁,也不会产生单例多线程问题.后面我才理解,如果加了第一层校验,则除例首次需要加锁外,后续都不会进行加锁操作,因为已经获取到了实例.如果只加一层校验锁,则每次获取都要加锁,无疑会加大了许多开销.
标签:加锁,双重,校验,SingletonTest,volatile,singletonTest,单例,null 来源: https://www.cnblogs.com/wangzxblog/p/15302745.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。