多线程循环打印输出问题(三)
程序员文章站
2024-03-21 12:48:52
...
//争抢的锁资源
public static Lock lock =new ReentrantLock();
//控制线程挂起和执行
public static Condition cond =lock.newCondition();
//保证线程优先执行
public volatile static boolean flag =true;
public static void main(String[] args) {
new Thread(new Runnable(){
@Override
public void run() {
lock.lock();
flag=false;
for(int i=0;i<5;i++){
System.out.println("a");
cond.signalAll();//唤醒挂起的线程
try {
cond.await();//自身挂起
} catch (InterruptedException e) {
e.printStackTrace();
}
}
cond.signalAll();
lock.unlock();
}
}).start();
new Thread(new Runnable(){
@Override
public void run() {
lock.lock();
if(flag){
try {
cond.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
for(int i=0;i<5;i++){
System.out.println("b");
cond.signalAll();
try {
cond.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
lock.unlock();
}
}).start();
}
和synchronized思路一样,都是控制线程的挂起和唤醒,还有注意对哪个线程优先的控制,后面想想volatile关键字,其实没有起到作用,加上锁的区域就保证了可见性,不需要用volatile了。