线程在工作中的应用
由于我们工作写的代码要求解耦,所以我们的类还是我们平时写的类,只是我们需要一个线程类去操作我们平时写的类
synchronized和lock区别
参考(点我)
使用synchronized实现
- 首先我们写一个我们平时写的类(SaleTicket)
- 我们写一个测试类
- 我们通过lambda表达式简写我们线程类
package com.yang.kuangTeacher;
/**
* @author: fudy
* @date: 2020/9/13 下午 03:49
* @Decription: 实际工作运用线程
**/
public class TrueThread {
public static void main(String[] args) {
SaleTicket saleTicket = new SaleTicket();
new Thread(()->{
for (int i = 0; i < 40; i++) {
saleTicket.sale();
}
},"黄牛:").start();
new Thread(()->{
for (int i = 0; i < 40; i++) {
saleTicket.sale();
}
},"12306:").start();
new Thread(()->{
for (int i = 0; i < 40; i++) {
saleTicket.sale();
}
},"柜台:").start();
}
}
class SaleTicket{
private int ticket = 30;
public synchronized void sale(){
if (ticket>0){
System.out.println(Thread.currentThread().getName()+"卖出了第"+(ticket--)+"票");
}
}
}
这里的实现和我的另一篇博客中讲的实现Callable接口实现多线程中的进阶使用类似,这些都是工作中使用多线程的思想。
使用Lock锁实现
package com.yang.kuangTeacher;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
/**
* @author: fudy
* @date: 2020/9/13 下午 03:49
* @Decription: 实际工作运用线程
**/
public class TrueThread2 {
public static void main(String[] args) {
SaleTicket saleTicket = new SaleTicket();
new Thread(()->{
for (int i = 0; i < 40; i++) {
saleTicket.sale();
}
},"黄牛:").start();
new Thread(()->{
for (int i = 0; i < 40; i++) {
saleTicket.sale();
}
},"12306:").start();
new Thread(()->{
for (int i = 0; i < 40; i++) {
saleTicket.sale();
}
},"柜台:").start();
}
}
class SaleTicket2{
private int ticket = 30;
// 用可重入锁这个实现类
Lock lock = new ReentrantLock();
public void sale(){
try {
// 加锁
lock.lock();
if (ticket>0){
System.out.println(Thread.currentThread().getName()+"卖出了第"+(ticket--)+"票");
}
}finally {
// 释放锁
lock.unlock();
}
}
}