synchronized和锁(ReentrantLock) 区别

java的两种同步方式, Synchronized与ReentrantLock的区别

并发(一):理解可重入锁

可重入锁和不可重入锁 ReentrantLock & synchronize

Java并发之ReentrantLock详解

 package mianshi.test;

 import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.ReentrantLock; class ReentrantLockTest {
public static ReentrantLock reenT = new ReentrantLock();// 参数默认false,不公平锁
private ReentrantLock lock = new ReentrantLock(true); // 公平锁 速度慢与不公平锁 /**
* 使用场景:(1)比如一个定时任务,第一次定时任务未完成,重复发起了第二次,直接返回flase;
* (2)用在界面交互时点击执行较长时间请求操作时,防止多次点击导致后台重复执行
*/
public static void tryLockTest() {
if (reenT.tryLock()) {
// 如果已经被lock,则立即返回false不会等待,
// 达到忽略操作的效果 ,当执行1000线程时,有些未获得对象锁的线程,会自动跳过
try {
// 操作
System.out.println("aaaa" + Thread.currentThread().getName());
} finally {
reenT.unlock();
} }
} /**
* 使用场景:(1)同步操作 类似于synchronized 如果被其它资源锁定,会在此等待锁释放,达到暂停的效果
* ReentrantLock存在公平锁与非公平锁 而且synchronized都是公平的
*/
public static void lockTest() {
try {
reenT.lock(); // 如果被其它资源锁定,会在此等待锁释放,达到暂停的效果
// 操作
System.out.println("aaaa" + Thread.currentThread().getName()); } finally {
reenT.unlock();
}
} /**
* 使用场景:(1)如果发现该操作正在执行,等待一段时间,如果规定时间未得到锁,放弃。防止资源处理不当,线程队列溢出,出现死锁
*/
public static void trylockTimeTest() {
try {
if (reenT.tryLock(5, TimeUnit.SECONDS)) { // 如果已经被lock,尝试等待5s,看是否可以获得锁,如果5s后仍然无法获得锁则返回false继续执行
Thread.sleep(6000);
try {
// 操作
System.out.println("aaaa"
+ Thread.currentThread().getName());
} finally {
reenT.unlock();
}
}
System.out
.println("如果发现该操作正在执行,等待一段时间,如果规定时间未得到锁,放弃。防止资源处理不当,线程队列溢出,出现死锁");
} catch (InterruptedException e) {
e.printStackTrace(); // 当前线程被中断时(interrupt),会抛InterruptedException
} } /**
* 使用场景:(1)中断正在进行的操作立刻释放锁继续下一操作.比如 取消正在同步运行的操作,来防止不正常操作长时间占用造成的阻塞
*/
public static void lockInterruptTest() {
try {
reenT.lockInterruptibly();
System.out.println("aaaa" + Thread.currentThread().getName());
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
reenT.unlock();
}
System.out.println("(1)中断正在进行的操作立刻释放锁继续下一操作.比如 取消正在同步运行的操作,来防止不正常操作长时间占用造成的阻塞");
} public void testlockInterruptTest() throws Exception {
final java.util.concurrent.locks.Lock lock = new ReentrantLock();
lock.lock();//长时间持有锁不释放,使用lockInterruptibly中断异常!!!
Thread.sleep(1000);
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
/*try{
lock.lock();
System.out.println("不会中断");
}finally{
lock.unlock();
}*/
try {
lock.lockInterruptibly();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()
+ " interrupted.");
}
});
t1.start();
Thread.sleep(1000);
t1.interrupt();
} public static void main(String[] args) { for (int i = 0; i < 1000; i++) {
new Thread(new Runnable() {
public void run() {
ReentrantLockTest.lockInterruptTest();
}
}).start();
} /*try {
ReentrantLockTest t = new ReentrantLockTest();
t.testlockInterruptTest();
} catch (Exception e) {
e.printStackTrace();
}*/
} }

synchronized和锁(ReentrantLock) 区别的更多相关文章

  1. 同步锁Synchronized与Lock的区别?

    synchronized与Lock两者区别: 1:Lock是一个接口,而Synchronized是关键字. 2:Synchronized会自动释放锁,而Lock必须手动释放锁. 3:Lock可以让等待 ...

  2. 深入理解java内置锁(synchronized)和显式锁(ReentrantLock)

    多线程编程中,当代码需要同步时我们会用到锁.Java为我们提供了内置锁(synchronized)和显式锁(ReentrantLock)两种同步方式.显式锁是JDK1.5引入的,这两种锁有什么异同呢? ...

  3. java synchronized和(ReentrantLock)区别

    原文:http://blog.csdn.net/zheng548/article/details/54426947 区别一:API层面 syschronized使用 synchronized即可修饰方 ...

  4. synchronized和ReentrantLock区别

    一.什么是sychronized sychronized是java中最基本同步互斥的手段,可以修饰代码块,方法,类. 在修饰代码块的时候需要一个reference对象作为锁的对象. 在修饰方法的时候默 ...

  5. Android进阶——多线程系列之wait、notify、sleep、join、yield、synchronized关键字、ReentrantLock锁

    多线程一直是初学者最困惑的地方,每次看到一篇文章,觉得很有难度,就马上叉掉,不看了,我以前也是这样过来的.后来,我发现这样的态度不行,知难而退,永远进步不了.于是,我狠下心来看完别人的博客,尽管很难但 ...

  6. synchronized关键字,Lock接口以及可重入锁ReentrantLock

    多线程环境下,必须考虑线程同步的问题,这是因为多个线程同时访问变量或者资源时会有线程争用,比如A线程读取了一个变量,B线程也读取了这个变量,然后他们同时对这个变量做了修改,写回到内存中,由于是同时做修 ...

  7. 深入分析ReentrantLock公平锁和非公平锁的区别

    在ReentrantLock中包含了公平锁和非公平锁两种锁,通过查看源码可以看到这两种锁都是继承自Sync,而Sync又继承自AbstractQueuedSynchronizer,而AbstractQ ...

  8. 深入分析ReentrantLock公平锁和非公平锁的区别 (转)

    在ReentrantLock中包含了公平锁和非公平锁两种锁,通过查看源码可以看到这两种锁都是继承自Sync,而Sync又继承自AbstractQueuedSynchronizer,而AbstractQ ...

  9. java8的ConcurrentHashMap为何放弃分段锁,为什么要使用CAS+Synchronized取代Segment+ReentrantLock

    原文地址:https://cloud.tencent.com/developer/article/1509556 推荐一篇 ConcurrentHashMap 和 HashMap 写的比较的的文章 j ...

随机推荐

  1. 已知空间两点组成的直线求线上某点的Z值

    已知空间两点组成的直线求线上某点的Z值,为什么会有这种看起来比较奇怪的求值需求呢?因为真正三维空间的几何计算是比较麻烦的,很多时候需要投影到二维,再反推到三维空间上去. 复习下空间直线方程:已知空间上 ...

  2. 【转载】script命令使用

    二.script命令简介当你在终端或控制台上工作时,你可能想记录下自己做了些什么.这种记录可以看成是保存了终端痕迹的文档.假设你跟一些Linux管理员同时在系统上干活.或者说你让别人远程到你的服务器. ...

  3. ‘.vue’文件(非常重要)

    ‘.vue’文件 Vue自定义了一种后缀名名字为.vue文件,它将html, js, css 整合成一个文件,和里面 template script style三个区别分别依次对应. 1 2 3 4 ...

  4. Languages-used-on-the-Internet

    Languages-used-on-the-Internet 1. 互联网上使用的语言 1.1 网站内容语言 1.2 按语言互联网用户 1.3 维基百科文章统计 2. 综合以上表格数据出图表(2019 ...

  5. 事件类型-UI事件、焦点事件

    DOM3级事件包括以下几类事件: UI事件:当用户与页面上的元素交互时触发 焦点事件:当元素获得或失去焦点时触发 鼠标事件:当用户通过鼠标在页面上执行操作时触发 滚轮事件:当使用鼠标滚轮时触发 文本事 ...

  6. 手机号----IP api

    /* *手机号码API */ $fPArr = iconv("gbk","utf-8",file_get_contents($fphone)); echo $f ...

  7. Python 基础之递归 递归函数 尾递归 斐波那契

    1.递归函数 定义:自己调用自己的函数递:去归:回有去有回是递归#(1)简单的递归函数def digui(n):    print(n)    if n > 0:        digui(n- ...

  8. Java日期时间API系列11-----Jdk8中java.time包中的新的日期时间API类,使用java8日期时间API重写农历LunarDate

    通过Java日期时间API系列7-----Jdk8中java.time包中的新的日期时间API类的优点,java8具有很多优点,现在网上查到的农历转换工具类都是基于jdk7及以前的类写的,下面使用ja ...

  9. 2020年digitalocean最新优惠码100美元奖励

    欧美免备案vps服务器digitalocean我用了四年,创建一台vps速度非常快. 由于中国用户扎堆购买Vultr和Linode线路,导致digitalocean中国用户少,反而更稳定.digita ...

  10. day13-Python运维开发基础(递归与尾递归)

    递归与尾递归 # ### 递归函数 """ 递归函数: 自己调用自己的函数 递:去 归:回 有去有回是递归 """ # 简单递归 def d ...