多线程:轮流执行输入输出

来源:互联网 发布:cst软件与其它软件对比 编辑:程序博客网 时间:2024/06/08 13:34


public class Res {
private String name;
private   String sex;
private    boolean flag=false;


public  synchronized void set(String name,String sex){
if(flag){

try {
this.wait();//等待....wait必须写在锁里且标示是哪个锁
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

this.name=name;
this.sex=sex;
flag=true;
this.notify();//唤醒....(唤醒最先等待的)notify必须写在锁里且标示是哪个锁
}
}


public synchronized  void out() {
// TODO Auto-generated method stub
if(!flag){
try {
this.wait();//等待....wait必须写在锁里且标示是哪个锁
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
System.out.println(name+"....."+sex);
flag=false;
this.notify();
}

}

//************************************************



public class Input implements Runnable{

private Res r;
Input(Res r){
this.r=r;
}
@Override
public void run() {
// TODO Auto-generated method stub
int x=0;
while(true){

if(x==0){
r.set("mike", "man");
}
else{
r.set("黎明", "famle");
}
x=(x+1)%2;

}
}
}
/*
 * wait() ,notify() ,notifyAll()
 * 都使用在同步中,因为要对持有监视器(锁)的线程操作
 * 为什么这些操作线程的方法要定义在Object类中?
 * 因为这些方法在操作同步中线程时,都必须要标示他们所操作线程持有的锁
 * 只有同一个锁上的被等待线程可以被同一个锁上的notify唤醒,不能被其他锁
 * 中的线程唤醒.
 * 而锁可以是任意对象,所以可以被任意对象调用的方法定义在object中
 */
//******************************************************************



public class Output implements Runnable{

private Res r;
Output(Res r){
this.r=r;
}
@Override
public void run() {
// TODO Auto-generated method stub
while(true){
r.out();
}
}


}

//***************************************************

/*
 * 线程间通讯
 * 其实就是多个线程在操作同一个资源
 * 但是操作的动作不同
 */
public class Demo5 {
public static void main(String[] args) {
Res r=new Res();
Input in=new Input(r);
Output out=new Output(r);

Thread t1=new Thread(in);
Thread t2=new Thread(out);
t1.start();
t2.start();
}
}

0 0
原创粉丝点击