• 黑马程序员多线程12天1


    /*
    线程间通讯:
    其实就是多个线程在操作同一个资源,
    但是操作的动作不同。
    
    */
    class Res
    {
        String name;
        String sex;
        boolean flag = false;
    }
    
    class Input implements Runnable
    {
        private Res r ;
        Input(Res r)
        {
            this.r = r;
        }
        public void run()
        {
            int x = 0;
            while(true)
            {
                synchronized(r)
                {
    
                    if(r.flag)
                        try{r.wait();}catch(Exception e){}
                    if(x==0)
                    {
                        r.name="mike";
                        r.sex="man";
                    }
                    else
                    {
                        r.name="丽丽";
                        r.sex = "女女女女女";
                    }
                    x = (x+1)%2;
                    r.flag = true;
                    r.notify();
                }
            }
        }
    }
    
    class Output implements Runnable
    {
        private Res r ;
        
        Output(Res r)
        {
            this.r = r;
        }
        public void run()
        {
            while(true)
            {
                synchronized(r)
                {
                    if(!r.flag)
                        try{r.wait();}catch(Exception e){}
                    System.out.println(r.name+"...."+r.sex);
                    r.flag = false;
                    r.notify();
                }
            }
        }
    }
    
    
    class  InputOutputDemo
    {
        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();
        }
    }
    
    
    //notifyAll();
    
    /*
    wait:
    notify();
    notifyAll();
    
    都使用在同步中,因为要对持有监视器(锁)的线程操作。
    所以要使用在同步中,因为只有同步才具有锁。
    
    为什么这些操作线程的方法要定义Object类中呢?
    因为这些方法在操作同步中线程时,都必须要标识它们所操作线程只有的锁,
    只有同一个锁上的被等待线程,可以被同一个锁上notify唤醒。
    不可以对不同锁中的线程进行唤醒。
    
    也就是说,等待和唤醒必须是同一个锁。
    
    而锁可以是任意对象,所以可以被任意对象调用的方法定义Object类中。
    
    
    */
  • 相关阅读:
    Java Gradle
    C/C++ C++11新特性
    C/C++ C++11原子类型和内存序
    基于流的编程(Flow-Based Programming)
    算法和数据结构 筛法求素数
    数据库 悲观锁和乐观锁
    数据库 事务隔离级别
    Serverless 的 AI 写诗,程序员浪漫起来谁能顶得住啊!
    亮点前瞻 | 首届 ServerlesssDays · China 大会议程发布
    腾讯云云函数 SCF Node.js Runtime 最佳实践
  • 原文地址:https://www.cnblogs.com/guwenren/p/3006381.html
Copyright © 2020-2023  润新知