大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

Java多線程編程概述
Java多線程的安全問題
Java多線程同步
Java多線程間的通信
Java線程Lock
Java多線程管理
保障線程安全的設計技術
Java鎖的優化及注意事項
Java多線程集合
【Java多線程】單例模式與多線程

Java多線程:newCondition()方法

關鍵字synchronized與wait()/notify()這兩個方法一起使用可以實現等待/通知模式, Lock鎖的newContition()方法返回Condition對象,Condition類也可以實現等待/通知模式。

用notify()通知時,JVM會隨機喚醒某個等待的線程, 使用Condition類可以進行選擇性通知, Condition比較常用的兩個方法:

● await()會使當前線程等待,同時會釋放鎖,當其他線程調用signal()時,線程會重新獲得鎖并繼續執行。

● signal()用于喚醒一個等待的線程。

注意:在調用Condition的await()/signal()方法前,也需要線程持有相關的Lock鎖,調用await()后線程會釋放這個鎖,在singal()調用后會從當前Condition對象的等待隊列中,喚醒 一個線程,喚醒的線程嘗試獲得鎖, 一旦獲得鎖成功就繼續執行。

package com.wkcto.lock.condition;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * Condition等待與通知
 */
public class Test01 {
    //定義鎖
    static Lock lock = new ReentrantLock();
    //獲得Condtion對象
    static Condition condition = lock.newCondition();

    //定義線程子類
    static class SubThread extends Thread{
        @Override
        public void run() {
            try {
                lock.lock();    //在調用await()前必須先獲得鎖
                System.out.println("method lock");
                condition.await();      //等待
                System.out.println("method  await");
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();      //釋放鎖
                System.out.println("method unlock");
            }
        }
    }

    public static void main(String[] args) throws InterruptedException {
        SubThread t = new SubThread();
        t.start();
        //子線程啟動后,會轉入等待狀態

        Thread.sleep(3000);
        //主線程在睡眠3秒后,喚醒子線程的等待
        try {
            lock.lock();
            condition.signal();
        } finally {
            lock.unlock();
        }
    }
}
package com.wkcto.lock.condition;

import java.io.PipedOutputStream;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;

/**
 * 多個Condition實現通知部分線程, 使用更靈活
 */
public class Test02 {
    static class Service{
        private ReentrantLock lock = new ReentrantLock();       //定義鎖對象
        //定義兩個Condtion對象
        private Condition conditionA = lock.newCondition();
        private Condition conditionB = lock.newCondition();

        //定義方法,使用conditionA等待
        public void waitMethodA(){
            try {
                lock.lock();
                System.out.println(Thread.currentThread().getName() + " begin wait:" + System.currentTimeMillis());
                conditionA.await();         //等待
                System.out.println(Thread.currentThread().getName() + " end wait:" + System.currentTimeMillis());
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }

        //定義方法,使用conditionB等待
        public void waitMethodB(){
            try {
                lock.lock();
                System.out.println(Thread.currentThread().getName() + " begin wait:" + System.currentTimeMillis());
                conditionB.await();         //等待
                System.out.println(Thread.currentThread().getName() + " end wait:" + System.currentTimeMillis());
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();
            }
        }

        //定義方法喚醒conditionA對象上的等待
        public void signalA(){
            try {
                lock.lock();
                System.out.println(Thread.currentThread().getName() + " sigal A time = " + System.currentTimeMillis());
                conditionA.signal();
                System.out.println(Thread.currentThread().getName() + " sigal A time = " + System.currentTimeMillis());
            } finally {
                lock.unlock();
            }
        }

        //定義方法喚醒conditionB對象上的等待
        public void signalB(){
            try {
                lock.lock();
                System.out.println(Thread.currentThread().getName() + " sigal A time = " + System.currentTimeMillis());
                conditionB.signal();
                System.out.println(Thread.currentThread().getName() + " sigal A time = " + System.currentTimeMillis());
            } finally {
                lock.unlock();
            }
        }

    }

    public static void main(String[] args) throws InterruptedException {
        Service service = new Service();

        //開啟兩個線程,分別調用waitMethodA(),waitMethodB()方法
        new Thread(new Runnable() {
            @Override
            public void run() {
                service.waitMethodA();
            }
        }).start();
        new Thread(new Runnable() {
            @Override
            public void run() {
                service.waitMethodB();
            }
        }).start();

        Thread.sleep(3000);         //main線程睡眠3秒
//        service.signalA();          //喚醒 conditionA對象上的等待,conditionB上的等待依然繼續等待
        service.signalB();
    }
}
package com.wkcto.lock.condition;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 *  使用Condition實現生產者/消費者設計模式, 兩個 線程交替打印
 */
public class Test03 {
    static class  MyService{
        private Lock lock = new ReentrantLock();        //創建鎖對象
        private Condition condition = lock.newCondition();  //創建Condition對象
        private boolean flag = true;        //定義交替打印標志

        //定義方法只打印----橫線
        public void printOne(){
            try {
                lock.lock();        //鎖定
                while (flag){      //當flag為true等待
                    System.out.println(Thread.currentThread().getName() + " waiting...");
                    condition.await();
                }
                //flag為false時打印
                System.out.println(Thread.currentThread().getName() + " ---------------- ");
                flag = true;        //修改交替打印標志
                condition.signal();     //通知另外的線程打印
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();      //釋放鎖對象
            }
        }

        //定義方法只打印***橫線
        public void printTwo(){
            try {
                lock.lock();        //鎖定
                while (!flag){      //當flag為false等待
                    System.out.println(Thread.currentThread().getName() + " waiting...");
                    condition.await();
                }
                //flag為true時打印
                System.out.println(Thread.currentThread().getName() + " ****** ");
                flag = false;        //修改交替打印標志
                condition.signal();     //通知另外的線程打印
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                lock.unlock();      //釋放鎖對象
            }
        }

    }

    public static void main(String[] args) {
        MyService myService = new MyService();
        //創建線程打印--
        new Thread(new Runnable() {
            @Override
            public void run() {
                for (int i = 0; i < 100; i++) {
                    myService.printOne();
                }
            }
        }).start();
        //創建線程打印**
        new Thread(new Runnable() {
            @Override
            public void run() {
                for (int i = 0; i < 100; i++) {
                    myService.printTwo();
                }
            }
        }).start();
    }
}

 

全部教程
主站蜘蛛池模板: 国内特级毛片 | 四虎影视永久免费视频观看 | 亚洲精品色综合久久久 | 中文国产成人精品久久无广告 | 久久天堂| 一日本道加勒比高清一二三 | 二区不卡 | 欧美成人午夜在线全部免费 | 奇米影 | 快色视频网站 | 717影院理论午夜伦八戒 | 欧美日韩成人在线视频 | 香蕉精品高清在线观看视频 | 日韩欧美中 | 亚洲成人第一 | 人做人爱视频欧美在线观看 | 天天干天天操天天射 | 中国一级特黄 | 国产综合精品久久亚洲 | 中文字幕在线免费观看视频 | 日本一区色| 成人啪啪97丁香 | 欧美成人禁片在线www | 热99re久久精品天堂vr | 91精品免费高清在线 | 国产综合成人亚洲区 | 亚洲成人视屏 | 午夜网站在线观看免费网址免费 | 97久久精品人人澡人人爽 | 中文字幕国产专区 | 成人午夜精品网站在线观看 | 国产福利精品在线观看 | 精品视频 九九九 | 色综合久久久久久久久五月性色 | 亚洲欧美日韩精品一区 | 中文字幕一区二区三区在线观看 | 久操视频网| 亚洲国产99在线精品一区二区 | 久久久999久久久精品 | 欧美国产亚洲精品a第一页 欧美国产亚洲精品高清不卡 | 一级寡妇乱色毛片全18 |