zoukankan      html  css  js  c++  java
  • 线程的通信

    • 其实就是多个线程在操作同一个资源,但是操作的动作不一样

    • 等待唤醒机制

      wait;
      notify();
      notifyAll();

    • 都是用在同步中,因为要对持有监视器(锁)的线程操作,所以都要使用在同步中,因为只有同步才具有锁

    为什么这些操作线程的方法要定义在Object类中呢?

        因为这些方法在操作同步中线程时,都必须要标识他们所操作线程持有的锁,
        只有同一个锁上的被等待线程,可以被同一个锁上的notify唤醒
        不可以对不同锁中的线程进行唤醒
        也就是说,等待和唤醒必须是同一个锁
        而锁可以是任意对象,所以可以被任意对象调用的方法定义在Object类中
    
    public static void main(String[] args) {
    		Res r = new Res();
    		
    		new Thread(new Input(r)).start();
    		new Thread(new Output(r)).start();
    }
    
    class Res {
    	private String name;
    	private String sex;
    	boolean flag = false;
    	public synchronized void set(String name, String sex) {
    		if(flag) {
    			try {
    				this.wait();
    			} catch (Exception e) {
    				System.out.println(e.toString());
    			}
    		}
    		this.name = name;
    		this.sex = sex;
    		flag = true;
    		this.notify();
    	}
    	public synchronized void out() {
    		if(!flag) {
    			try {
    				this.wait();
    			} catch (Exception e) {
    				System.out.println(e.toString());
    			}
    		}
    		System.out.println(name+" "+sex);
    		this.flag = false;
    		this.notify();
    	}
    }
    
    class Input implements Runnable {
    	private Res r;
    	Input(Res r) {
    		this.r = r;
    	}
    	public void run() {
    		int x = 0;
    		boolean b = true;
    		while(true) {
    			if(x == 0){
    				r.set("mike", "man");
    			}else{
    				r.set("丽丽", "女");
    			}
    			x = (x+1)%2;
    		}
    	}
    }
    
    class Output implements Runnable {
    	private Res r;
    	Output(Res r) {
    		this.r = r;
    	}
    	public void run() {
    		while(true) {
    			r.out();
    		}
    	}
    }
    
    
  • 相关阅读:
    用户体验评价
    第十三周总结
    第十二周总结
    单词统计
    第十一周总结
    冲刺(十一)
    用户模板和用户场景
    冲刺(十)
    冲刺(九)
    IOS 学习记录
  • 原文地址:https://www.cnblogs.com/rancvl/p/5465207.html
Copyright © 2011-2022 走看看