“建议127:Lock与synchronized是不一样的问题”实际验证
近期又一次翻看 “编写高质量代码:改善Java程序的151个建议” 一书的时候看到“建议127”的文章中作者提供的測试用例存在一些值得商榷的地方。
在使用作者的測试用例得出的结论大概是“ Synchronized 的对象方法调用中。多线程会是相互排斥的方式调用(可理解为线程竞争下依次运行,但不能保证顺序),而使用显示锁即lock.lock的方式下,多线程间是能够并发进行的”。
(此处的很多其它细节能够看原书的描写叙述)
细致分析代码后,我发现在代码中用Synchronized 的时候是对字面量 “A” 这个来进行加锁。在java里面,字面量都是会放到常量池中的。所以多个线程调用Synchronized(“A”)这种方法的时候。都会出现线程相互排斥。
而作者 对于Lock的測试则 使用的一个 类的私有Lock对象进行,那么每一个线程得到是不同的锁(或者都拿到了自己的锁)。则不存在线程间堵塞的问题。假设将Synchronized(“A”)keyword同步的方式改动为Synchronized(obj)即对一个内部的私有对象进行加锁。那么线程间也不存在堵塞的问题了。
以上是我个人的一个简单结论。有疑问的能够吐槽。我的简版測试代码例如以下:
public class TestThread {
public static class TestTask implements Runnable{
final Object lock1 = new Object();
private String threadName;
public TestTask(String threadName){
this.threadName =threadName;
}
@Override
public void run() {
System.out.println("===>"+threadName+" will access the lock");
long b = System.currentTimeMillis();
synchronized(lock1){//此处能够得出并发运行的结论
//synchronized("A"){//使用此处的方式则能够得出相互排斥的结论
try {
System.out.println("===>"+threadName+" run");
TimeUnit.SECONDS.sleep(5);
} catch (Exception e) {
e.printStackTrace();
}
}
long e = System.currentTimeMillis();
System.out.println("===>"+threadName+" run finished : "+(e-b));
}
};
public static void main(String[] args) {
Thread t3 = new Thread(new TestTask("t3"));
Thread t4 = new Thread(new TestTask("t4"));
Thread t5 = new Thread(new TestTask("t5"));
t3.start();
t4.start();
t5.start();
}
===========================================================
synchronized("A")的方式 输出例如以下:
===>t4 will access the lock
===>t3 will access the lock
===>t5 will access the lock
===>t4 run
===>t5 run
===>t4 run finished : 5003
===>t3 run
===>t5 run finished : 10004
===>t3 run finished : 15005
synchronized(lock1)的方式 输出例如以下:
===>t5 will access the lock
===>t3 will access the lock
===>t4 will access the lock
===>t3 run
===>t5 run
===>t4 run
===>t3 run finished : 5004
===>t4 run finished : 5004
===>t5 run finished : 5004
注意 观察输出从时间
“建议127:Lock与synchronized是不一样的问题”实际验证的更多相关文章
- Lock、synchronized和ReadWriteLock,StampedLock戳锁的区别和联系以及Condition
https://www.cnblogs.com/RunForLove/p/5543545.html 先来看一段代码,实现如下打印效果: 1 2 A 3 4 B 5 6 C 7 8 D 9 10 E 1 ...
- (转)Lock和synchronized比较详解
今天看了并发实践这本书的ReentantLock这章,感觉对ReentantLock还是不够熟悉,有许多疑问,所有在网上找了很多文章看了一下,总体说的不够详细,重点和焦点问题没有谈到,但这篇文章相当不 ...
- Lock较synchronized多出的特性
1.尝试非阻塞形式获取锁 tryLock() :当前线程尝试获取锁,如果锁被占用返回false;如果成功则占有锁 //类似用法if(lock.tryLock()) { try { System.out ...
- Java中的Lock与synchronized
并发编程学习笔记之Lock与synchronized 一.什么是可重入锁 Lcok在Java中是一个接口,一般在面试问题中问到的可能是ReentrantLock与synchronized的区别.Ree ...
- Lock和Synchronized
1.synchronized无法判断是否获取锁的状态,Lock可以判断是否获取锁2.Lock中的某些锁允许对共享资源的并发访问,如ReadWriteLock读写锁,readLock()获取读锁,wri ...
- Lock与synchronized的区别(浅谈)
Lock是一个接口 synchronized是一个关键字 Lock用法: synchronized用法: lock.lock() ...
- Java同步锁——lock与synchronized 的区别【转】
在网上看来很多关于同步锁的博文,记录下来方便以后阅读 一.Lock和synchronized有以下几点不同: 1)Lock是一个接口,而synchronized是Java中的关键字,synchroni ...
- 线程(六)之LOCK和synchronized
在java.util.concurrent.locks包中有很多Lock的实现类,常用的有ReentrantLock.ReadWriteLock(实现类ReentrantReadWriteLock), ...
- Lock和synchronized的区别和使用
Java并发编程:Lock 今天看了并发实践这本书的ReentantLock这章,感觉对ReentantLock还是不够熟悉,有许多疑问,所有在网上找了很多文章看了一下,总体说的不够详细,重点和焦点问 ...
随机推荐
- css加载方式link和@import的区别!
本质上,这两种方式都是为了加载CSS文件,但还是存在着细微的差别. 1. 老祖宗的差别.link属于XHTML标签,而@import完全是CSS提供的一种方式. link标签除了可以加载CSS外,还可 ...
- BZOJ4029 HEOI2015定价
贪心. 每次将最后一个非零位加一判断即可. 一开始想少了,只关心把最后一位变成5了,其实可以都变的. #include<bits/stdc++.h> using namespace std ...
- BZOJ1019 汉诺塔
定义f[i][j]为将i柱上的j个盘挪走(按优先级)的步数 p[i][j]为将i柱上的j个盘按优先级最先挪至何处 首先考虑一定p[i][j]!=i 设初始为a柱,p[i][j-1]为b柱 考虑两种情况 ...
- Java并发(九):重入锁 ReentrantLock
先做总结: 1.为什么要用ReentrantLock? (1)ReentrantLock与synchronized具有相同的功能和内存语义: (2)synchronized是重量级锁,性能不好.Ree ...
- Java反射机制涉及的类常见方法使用总结
import java.lang.reflect.Constructor; import java.lang.reflect.*; /*Class:代表一个字节码文件的对象,每当有类被加载进内存,JV ...
- 【ArcGIS笔记】数据处理
1.ARCGIS在导入Excel坐标点的时候出现"没有注册类"的情况怎么办? 确保你本机上装有office,并且版本要能够识别XLSX格式.2007以上. 2.导入excel时re ...
- python开发_counter()
在python的API中,提到了Counter,它具有统计的功能 下面是我做的demo: 1.统计自定义字符串中每个字符出现的次数 2.读取一个文件,把文件中的内容转化为字符串,统计该字符串中每个字符 ...
- leetcode 587. Erect the Fence 凸包的计算
leetcode.587.Erect the Fence 凸包问题.好像是我在leetcode做的第一个凸包问题吧. 第一次做,涉及到的东西还是蛮多的.有一个东西很重要,就是已知一个点和一个矢量,求这 ...
- 给WebAPI的REST接口添加测试页面(二)
在上篇文章中,我对Swagger-UI的基本功能进行了一些介绍,今天在这里介绍一下如何在WebAPI中集成Swagger-UI.这里以一个简单的CRUD的REST服务为例. /// <summa ...
- HDU 4496 D-City (并查集,水题)
D-City Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65535/65535 K (Java/Others)Total Subm ...