Java--面包师与消费者1(发送与接收线程)

线程的竞争关系:死锁和饥饿。
而线程的调度由操作系统调度:1)一次只能一个线程在临界区
2)不能让一个线程无限留在临界区
3)不能强迫一个线程无限等待进入临界区。特别,进入临界区的任一线程不能妨碍正等待进入的其他线程
下面是线程之间协作的演示,没有加锁

public class buffer {//缓冲区

    private int val;//共享变量
    public void ut(int i){
        this.val=i;
    }
    public int et(){
        return val;
    }
}
class Sender extends Thread{//发送线程
    private buffer buf;

    public Sender(buffer buf) {
        this.buf=buf;
    }
    public void run() {
        for(int i=1;i<6;i++){//连续向缓冲区发送信息
            buf.put(i);//指定缓冲区
            System.out.println("sender put:"+i);

            try {
                sleep(1);
            } catch (InterruptedException e) {

            }
        }
    }

}
class Receiver extends Thread{//接收线程
    private buffer buf;
    public Receiver(buffer buf) {
        this.buf=buf;
    }
    public void run() {
        for(int i=1;i<6;i++){//连续从缓冲区接收信息
            System.out.println(" Receiver get:"+buf.get());

            try {
                sleep(1);
            } catch (InterruptedException e) {

            }
        }
    }
    public static void main(String args[]){
        buffer buf=new buffer();
        (new Sender(buf)).start();
        (new Receiver(buf)).start();
    }
}

运行结果1:
sender put:1
Receiver get:1
Receiver get:1
sender put:2
Receiver get:3
sender put:3
Receiver get:3
sender put:4
Receiver get:4
sender put:5
运行结果2:
sender put:1
Receiver get:1
sender put:2
Receiver get:2
Receiver get:3
sender put:3
Receiver get:4
sender put:4
Receiver get:5
sender put:5

你可能感兴趣的:(线程)