Syncrhonized 和 Lock的区别和使用
相信很多小伙伴们初学多线程的时候会被这两个名词搞晕,所以这里专门介绍这两种实现多线程锁的方式的区别和使用场景
Synchronized
这个关键词大家肯定都不陌生,具体的用法就是使用在对象、类、方法上
- 当使用在对象和对象方法上的时候,就会获取相应的对象锁
public synchronized void method() {
// do something
}
- 当使用在类、类属性、类方法上的时候,就会获取相应的类对象锁
public class A {
pubilc void method() {
synchronized(A.class) {
// do something
}
}
}
用法大概就是上面这两种了
使用synchronized方法的好处就是很简单,上锁解锁都是自动完成的,代码的可读性也是很好的
但是,万事都有利弊,synchronized的简单必然会导致他的灵活性会比较差
尤其是当我们想用到多个锁的时候,或者一个锁有多个条件的时候,这种方法都是难以实现的
所以下面我将介绍本文的主角,Lock对象
Lock
Lock本身是一个接口,有兴趣的小伙伴可以查看源码
在JDK中只有ReenterLock实现了Lock,而这个ReenterLock也就是我们常听到的重入锁
那么如何使用Lock呢,Lock又有哪些好处呢,下面一一道来
Lock的使用需要手动上锁解锁的
Lock lock = new ReenterLock();
lock.lock();
try {
//do something
} catch(IntruptException e) {
e.printStack();
} finally {
lock.unlock();
}
看起来麻烦了很多,但是麻烦是有回报的
首先,我们可以很自由的获取和释放锁
其次,我们可以通过使用Condition来更加灵活地控制一个锁
不咕不咕,绝不咕咕咕
我们下面分别举例说明这两个好处
①可以自由获取和释放
给出下面一个场景
lock.lock();
if(/*condition*/) {
lock.unlock();
}
else {
// do someting
lock.unlock();
}
这个例子举的不是很恰当,因为不太符合Lock的使用规范,但是表现出了这个优点,这种灵活性是synchronized不具备的
②可以通过Condition来更加灵活地控制一个锁
怎么个灵活呢,说白了就是可以有选择的睡眠和唤醒,下面给一个例子
背景是常见的生产者——消费者模型
我们希望当没有东西了消费者就等待,等待前唤醒生产者
东西满了生产者就等待,等待前唤醒消费者
要是用synchronized就不好实现这个逻辑,因为我们其实只有一个临界资源,只是不同的条件而已
但是用Lock就可以有效解决这个问题
Lock lock = new Lock();
Condition empty = lock.newCondition();
Condition full = lock.newCondition();
构造生产者和消费者的时候,将两个条件和锁传入
//Builder
lock.lock();
try {
if(isEmpty()) {
full.await();
}
// building...
if(isFull()) {
empty.await();
}
}
// Consumer
lock.lock();
try {
if(isFull()) {
empty.signalAll();
}
// consuming
if(isEmpty()) {
full.await();
}
}
这样,两个线程就可以通过两个Condition来通信,虽然两个线程都使用同一个锁,但是每次唤醒的时候都是有选择地唤醒。
如果有多个消费者和生产者,那么,这种方式可以保证消费者每次唤醒的都是生产者,生产者每次唤醒的都是消费者。
初次原创博客,思路不是很清晰,本人也在不断学习中,如有错误、纰漏,欢迎大神指出(orz
Syncrhonized 和 Lock的区别和使用的更多相关文章
- C#知识点总结系列:4、C#中Monitor和Lock以及区别
Monitor对象 1.Monitor.Enter(object)方法是获取锁,Monitor.Exit(object)方法是释放锁,这就是Monitor最常用的两个方法,当然在使用过程中为了避免获取 ...
- C#中Monitor和Lock以及区别
Monitor对象 1.Monitor.Enter(object)方法是获取锁,Monitor.Exit(object)方法是释放锁,这就是Monitor最常用的两个方法,当然在使用过程中为了避免获取 ...
- hibernate中load,get;find,iterator;merge,saveOrUpdate,lock的区别
hibernate中load,get;find,iterator;merge,saveOrUpdate,lock的区别 转自http://www.blogjava.net/bnlovebn/archi ...
- Java中synchronized和Lock的区别
synchronized和Lock的区别synchronize锁对象可以是任意对象,由于监视器方法必须要拥有锁对象那么任意对象都可以调用的方法所以将其抽取到Object类中去定义监视器方法这样锁对象和 ...
- Synchronize 和 Lock 的区别与用法
一.synchronized和lock的用法区别 (1)synchronized(隐式锁):在需要同步的对象中加入此控制,synchronized可以加在方法上,也可以加在特定代码块中,括号中表示需要 ...
- 详解synchronized与Lock的区别与使用
知识点 1.线程与进程 在开始之前先把进程与线程进行区分一下,一个程序最少需要一个进程,而一个进程最少需要一个线程.关系是线程–>进程–>程序的大致组成结构.所以线程是程序执行流的最小单位 ...
- Java synchronized和 Lock 的区别与用法
在分布式开发中,锁是线程控制的重要途径.Java为此也提供了2种锁机制,synchronized和lock.做为Java爱好者,自然少不了对比一下这2种机制,也能从中学到些分布式开发需要注意的地方. ...
- 同步锁Synchronized与Lock的区别?
synchronized与Lock两者区别: 1:Lock是一个接口,而Synchronized是关键字. 2:Synchronized会自动释放锁,而Lock必须手动释放锁. 3:Lock可以让等待 ...
- 锁、C#中Monitor和Lock以及区别
1.Monitor.Enter(object)方法是获取锁,Monitor.Exit(object)方法是释放锁,这就是Monitor最常用的两个方法,当然在使用过程中为了避免获取锁之后因为异常,致锁 ...
随机推荐
- J2EE导论 | 疑惑篇
J2EE是Java程序员从新手进阶的一个必经之路.要体会所谓的工业级代码,就必须要融入和经历更为复杂的开发.部署环境,需要同更多的模块.组件做信息流交换,比较和使用不同的框架,逐一去琢磨和考察它们的必 ...
- Android X 相关汇总
一.说明 官方原文如下: We hope the division between android.* and androidx.* makes it more obvious which APIs ...
- vi命令详解(转)
vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令.由于对Unix及Linux系统的任何版本,vi编辑器是完全相 ...
- 《http权威指南》读书笔记14
概述 最近对http很感兴趣,于是开始看<http权威指南>.别人都说这本书有点老了,而且内容太多.我个人觉得这本书写的太好了,非常长知识,让你知道关于http的很多概念,不仅告诉你怎么做 ...
- ruby-操作mysql
ruby操作mysql数据库 以centos7.2为实验环境 Table of Contents 使用DBI访问Mysql 使用Mysql2访问Mysql DBI 安装DBI驱动 很多同学在公司是没有 ...
- Ocelot简易教程(一)之Ocelot是什么
作者:依乐祝 原文地址:https://www.cnblogs.com/yilezhu/p/9557375.html Ocelot简易教程目录 Ocelot简易教程(一)之Ocelot是什么 Ocel ...
- Parquet 格式文件,查看Schema
需要社区工具:parquet-tools-1.6.0rc3-SNAPSHOT.jar git project: https://github.com/apache/p ...
- Google的java工具类Guava
前言 google开发java项目肯定也不想重复造轮子,所以肯定也有工具类,就是它了:Guava 我将举例几个实际的例子,发挥这个工具类好用的功能.更多的方法和功能,还有内部的实现可以直接参考http ...
- c# Console application Open/Get Url by Browser
C# url 用 浏览器打开.C#获取浏览器的url static void Main(string[] args) { string file = @"C:\Users\Hero\Desk ...
- 基于redis的分布式锁实现
1.分布式锁介绍 在计算机系统中,锁作为一种控制并发的机制无处不在. 单机环境下,操作系统能够在进程或线程之间通过本地的锁来控制并发程序的行为.而在如今的大型复杂系统中,通常采用的是分布式架构提供服务 ...