多线程之死锁、生产者与消费者模型以及线程池
            时间:2021-06-30 18:01:58  
            收藏:0  
            阅读:0
        
        
        - 
互斥条件:一个资源每次只能被一个进程使用
 - 
请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放
 - 
不剥夺条件:进程已获得的资源,在未使用完之前,不能强制剥夺
 - 
 
实例
package com.yeyue.thread;
?
public class DeadLock {
    public static void main(String[] args) {
        new Makeup(0,"灰姑凉").start();
        new Makeup(1,"白雪公主").start();
    }
?
}
?
//口红
class Lipstick{
?
}
?
//镜子
class Mirror {
?
}
?
class Makeup extends Thread {
?
    //需要的资源只有一份,用static来保证只有一份
    static Lipstick lipstick = new Lipstick();
    static Mirror mirror = new Mirror();
?
    int choice;
    String girlName;
?
    Makeup(int choice, String girlName) {
        this.choice = choice;
        this.girlName = girlName;
    }
?
    
避免死锁
package com.yeyue.thread;
?
public class DeadLock {
    public static void main(String[] args) {
        new Makeup(0,"灰姑凉").start();
        new Makeup(1,"白雪公主").start();
    }
?
}
?
//口红
class Lipstick{
?
}
?
//镜子
class Mirror {
?
}
?
class Makeup extends Thread {
?
    //需要的资源只有一份,用static来保证只有一份
    static Lipstick lipstick = new Lipstick();
    static Mirror mirror = new Mirror();
?
    int choice;
    String girlName;
?
    Makeup(int choice, String girlName) {
        this.choice = choice;
        this.girlName = girlName;
    }
?
    
synchronized与lock的对比
- 
lock是显示锁(手动开启和关闭锁,别忘记关锁)synchronized是隐式锁,除了作用域自动释放
 - 
lock只有代码块锁,synchronized有代码块锁和方法锁
 - 
使用lock锁,jvm将花费较少的时间来调度线程,性能更好。而且具有更好的扩展性(提供更多的子类)
 - 
优先使用顺序:
lock>同步代码块(已经进入方法体,分配了相应资源)>同步方法(在方法体之外)
实例
package com.yeyue.thread;
?
import java.util.concurrent.locks.ReentrantLock;
?
public class TestLock {
public static void main(String[] args) {
TestLock2 testLock2 = new TestLock2();
?
new Thread(testLock2).start();
new Thread(testLock2).start();
new Thread(testLock2).start();
}
}
?
class TestLock2 implements Runnable{
?
int ticketNums = 10;
//定义lock锁
private final ReentrantLock lock = new ReentrantLock();
?
 
生产者消费者模型-->利用缓冲区解决:管程法
package com.yeyue.thread;
?
//测试:生产者消费者模型-->利用缓冲区解决:管程法
?
//生产者,消费者,产品,缓冲区
public class TestPC {
    public static void main(String[] args) {
        SynContainer container = new SynContainer();
?
        new Productor(container).start();
        new Consumer(container).start();
?
    }
}
?
//生产者
class Productor extends Thread{
    SynContainer container;
?
    public Productor(SynContainer container){
        this.container = container;
    }
?
    //生产