线程的竞争关系:死锁和饥饿。
而线程的调度由操作系统调度: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