package zhu.suo;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class CondotionDemo {
public static void main(String[] args) {
final Test test= new Test();//
//子线程
new Thread(
new Runnable() {
@Override
public void run() {
for(int i=1;i<51;i++ )
test.sub(i);
}
}
).start();
//主线程
for(int i=1;i<51;i++ )
test.main(i);
}
}
class Test{
boolean IsSubTrue=true;
private Lock lock = new ReentrantLock();
Condition condition = lock.newCondition();
void sub(int i){
lock.lock();
try{
while(!IsSubTrue)//如果子线程标识为false,则子线程等待
{
try {
condition.await();//await是condition所关联的锁 对应线程专属等待
} catch (Exception e) {
e.printStackTrace();
}
}
//否则执行
for(int j=1;j<=10;j++)
{
System.out.println("子线程循环"+j+"次,到第"+i+"圈");
}
//执行后修改标识 并且释放一个等待线程
IsSubTrue=false;
condition.signal();
}finally{
lock.unlock();
}
}
synchronized void main(int i){
lock.lock();
try{
while(IsSubTrue)//如果子线程标识为true,则主线程等待 使用while相对于if的好处是防止伪唤醒
{
try {
condition.await();//
} catch (InterruptedException e) {
e.printStackTrace();
}
}
for(int j=1;j<=100;j++)
{
System.out.println("主线程循环"+j+"次,到第"+i+"圈");
}
//
IsSubTrue=true;
condition.signal();
}finally{
lock.unlock();
}
}
}
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class CondotionDemo {
public static void main(String[] args) {
final Test test= new Test();//
//子线程
new Thread(
new Runnable() {
@Override
public void run() {
for(int i=1;i<51;i++ )
test.sub(i);
}
}
).start();
//主线程
for(int i=1;i<51;i++ )
test.main(i);
}
}
class Test{
boolean IsSubTrue=true;
private Lock lock = new ReentrantLock();
Condition condition = lock.newCondition();
void sub(int i){
lock.lock();
try{
while(!IsSubTrue)//如果子线程标识为false,则子线程等待
{
try {
condition.await();//await是condition所关联的锁 对应线程专属等待
} catch (Exception e) {
e.printStackTrace();
}
}
//否则执行
for(int j=1;j<=10;j++)
{
System.out.println("子线程循环"+j+"次,到第"+i+"圈");
}
//执行后修改标识 并且释放一个等待线程
IsSubTrue=false;
condition.signal();
}finally{
lock.unlock();
}
}
synchronized void main(int i){
lock.lock();
try{
while(IsSubTrue)//如果子线程标识为true,则主线程等待 使用while相对于if的好处是防止伪唤醒
{
try {
condition.await();//
} catch (InterruptedException e) {
e.printStackTrace();
}
}
for(int j=1;j<=100;j++)
{
System.out.println("主线程循环"+j+"次,到第"+i+"圈");
}
//
IsSubTrue=true;
condition.signal();
}finally{
lock.unlock();
}
}
}