36套java进阶高级架构师视频+38套大数据视频 保证全是硬货需要的
+微信:
du13797566440
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;
/**重入锁ReentrantLock(软穿特lock)
*/
public class worker {
private ReentrantLock lock=new ReentrantLock();//创建锁
private Condition con= lock.newCondition();//控制线程获取释放锁 ,可以创建多个con,实现线程分类控制
public void m1(){
try {
lock.lock(); //开启锁
System.out.println("m1等待");
con.await(); //当前线程阻塞释放锁,相当于synchronized的wait();
System.out.println("m2唤醒");
} catch (Exception e) {
}finally {
lock.unlock();//必须释放锁
}
}
public void m2(){
try {
lock.lock(); //开启锁
System.out.println("m2执行");
Thread.sleep(2000);
con.signal();//唤醒一个被await的线程 不释放锁,相当于synchronized的nitify();
//con.signalAll();
System.out.println("m2结束");
} catch (Exception e) {
}finally {
lock.unlock();//必须释放锁
}
}
public static void main(String[] args) {
ExecutorService newCachedThreadPool = Executors.newCachedThreadPool();
final worker worker = new worker();
newCachedThreadPool.execute(new Runnable() {
public void run() {
worker.m1();
}
});
newCachedThreadPool.execute(new Runnable() {
public void run() {
worker.m2();
}
});
}
}
----------------------------
m1等待
m2执行
m2结束
m2唤醒