synchronized是关键字Lock是一个类。

synchronized是个全自动会自动释放锁 Lock是手动的 。

synchronized无法判断获取锁的状态Lock可以判断。

synchronized 线程1 (获得锁, 阻塞了) 线程2 (等待, 一直等) Lock锁就不一定会一直等下去
会有locak.tryLock()尝试获取锁。

synchronized 可重入锁,不可中断 , 非公平 ; Lock 可重入锁,可以判断锁, 默认非公平(可以自己设置)。

synchronized 适合锁少量的同步代码, Lock适合锁大量的同步代码。

synchronized 可以锁代码块和方法, Lock只能锁代码块。

使用Lock锁JVM将花费较少的时间来调度线程,性能更好, 并且可扩展性好 有更多的子类。

Lock分为三部分

ReentrantLock() 可重入锁ReentrantReadWriteLock.ReadLock() 读锁ReentrantReadWriteLock.WriteLock() 写锁 public ReentrantLock() {
sync = new NonfairSync();
}

/**
* Creates an instance of {@code ReentrantLock} with the
* given fairness policy.
*
* @param fair {@code true} if this lock should use a fair ordering policy
*/
public ReentrantLock(boolean fair) {
sync = fair ? new FairSync() : new NonfairSync();
}

这里是可重入锁 ReentrantLock() 的源码

不传参数的时候默认是非公平锁=============》不按顺序来的 可插队
传参是true时候是公平锁,false时候是非公平锁 =========》 手机号交易完全按照顺序执行 存在3s的进程等到3h的进程

写法上区别

synchronized

/**
* 注释
*
* @author sunhao
* @Date 2021-08-23-21:11
*/
public class Test01 {

public static void main(String[] args) {
Book book = new Book();

new Thread(() -> { for (int i = 0; i < 60; i++) book.sell(); }, "A").start();
new Thread(() -> { for (int i = 0; i < 60; i++) book.sell(); }, "B").start();
new Thread(() -> { for (int i = 0; i < 60; i++) book.sell(); }, "C").start();
}
}


class Book{
int num = 60;
public synchronized void sell(){
if (num > 0)
System.out.println(Thread.currentThread().getName()+"卖出了第" + (num--)+ "本剩余" + num + "本");
}

// Lock lock = new ReentrantLock();
// public void sell(){
// lock.lock();
// try {
// if (num > 0)
// System.out.println(Thread.currentThread().getName()+"卖出了第" + (num--)+ "本剩余" + num + "本");
// } catch (Exception e) {
// e.printStackTrace();
// } finally {
// lock.unlock();
// }
// }

}

new ReentrantLock();

Lock分为三部曲
1.new ReentrantLock();
2.lock.lock();
3.try-catch-finally=>lock.unlock();

/**
* 注释
*
* @author sunhao
* @Date 2021-08-23-21:11
*/
public class Test01 {

public static void main(String[] args) {
Book book = new Book();

new Thread(() -> { for (int i = 0; i < 60; i++) book.sell(); }, "A").start();
new Thread(() -> { for (int i = 0; i < 60; i++) book.sell(); }, "B").start();
new Thread(() -> { for (int i = 0; i < 60; i++) book.sell(); }, "C").start();
}
}


class Book{
int num = 60;
// public synchronized void sell(){
// if (num > 0)
// System.out.println(Thread.currentThread().getName()+"卖出了第" + (num--)+ "本剩余" + num + "本");
// }

Lock lock = new ReentrantLock();
public void sell(){
lock.lock();
try {
if (num > 0)
System.out.println(Thread.currentThread().getName()+"卖出了第" + (num--)+ "本剩余" + num + "本");
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}

}

更多相关文章

  1. 工作中线程的启动
  2. .NET Core 中的并发编程
  3. Executors创建线程池有哪几种方式?
  4. js事件,线程,定时器
  5. flex布局-实践
  6. 前端作业-flex布局
  7. flex容器与项目的认识和常用属性
  8. QT5 关于object基类实现的多线程操作,movetothread方法的使用
  9. 线程优化Python写GUI业务卡顿问题

随机推荐

  1. Android的支持库 && app/apk包进系统 &&
  2. 如何在Android应用里对HTTP请求头部添加
  3. 解决android调用系统相机拍照保存时onAct
  4. 路径提供者文档目录是一个安全的位置吗?
  5. 如何在Android 7.0+中检索SD卡的序列号?
  6. Android多线程下载远程图片【转】
  7. 转:Android Studio Error:Connection time
  8. MD5加密,java工具类 String 转变成MD5 St
  9. 没有包lib32z1,lib32ncurses5,lib32stdc+
  10. Android TextView设置字体风格