<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • Java中Queue和BlockingQueue的區(qū)別

    時間:2024-07-23 02:57:25 SUN認(rèn)證 我要投稿
    • 相關(guān)推薦

    關(guān)于Java中Queue和BlockingQueue的區(qū)別

      隊(duì)列是一種特殊的線性表,它只允許在表的前端(front)進(jìn)行刪除操作,而在表的后端(rear)進(jìn)行插入操作。進(jìn)行插入操作的端稱為隊(duì)尾,進(jìn)行刪除操作的端稱為隊(duì)頭。隊(duì)列中沒有元素時,稱為空隊(duì)列。下面小編準(zhǔn)備了關(guān)于Java中Queue和BlockingQueue的區(qū)別,提供給大家參考!

      1.BlockingQueue:支持兩個附加操作的 Queue,這兩個操作是:檢索元素時等待隊(duì)列變?yōu)榉强眨约按鎯υ貢r等待空間變得可用。

      2.BlockingQueue 不接受 null 元素。

      3.BlockingQueue 可以是限定容量的。

      4.BlockingQueue 實(shí)現(xiàn)是線程安全的。Queue不是線程安全的。因此可以將Blockingqueue用于用于生產(chǎn)者-使用者隊(duì)列。

      根據(jù)Api修改的一個例子,大家可以修改自己體驗(yàn)BlockingQueue的使用

      package test;

      import java.util.concurrent.ArrayBlockingQueue;

      import java.util.concurrent.BlockingQueue;

      /**

      * 生產(chǎn)者

      */

      class Producer implements Runnable {

      private final BlockingQueue queue;

      Producer(BlockingQueue q) {

      queue = q;

      }

      public void run() {

      try {

      for (int i = 0; i < 3; i++) {

      queue.put(produce());

      System.out.println("生產(chǎn)后:"+queue.peek());

      }

      } catch (InterruptedException ex) {

      ex.printStackTrace();

      }

      }

      Character produce() {

      char c = (char) (Math.random() * 26 + 'A');

      System.out.println("生產(chǎn)前:" + c);

      return c;

      }

      }

      /**

      * 消費(fèi)者

      */

      class Consumer implements Runnable {

      private final BlockingQueue queue;

      Consumer(BlockingQueue q) {

      queue = q;

      }

      public void run() {

      try {

      while (true) {

      consume(queue.take());

      //Thread.sleep(100);

      }

      } catch (InterruptedException ex) {

      ex.printStackTrace();

      }

      }

      void consume(Character c) {

      System.out.println("消費(fèi):" + c);

      }

      }

      /**

      * 一個生產(chǎn)者、兩個消費(fèi)者

      *

      */

      class Setup {

      public static void main(String[] args) {

      BlockingQueue q = new ArrayBlockingQueue(1);

      Producer p = new Producer(q);

      Consumer c1 = new Consumer(q);

      Consumer c2 = new Consumer(q);

      new Thread(p).start();

      new Thread(c1).start();

      new Thread(c2).start();

      }

      }

      –EOF–

    【Java中Queue和BlockingQueue的區(qū)別】相關(guān)文章:

    JAVA和.NET開發(fā)過程中的區(qū)別10-25

    Java Web開發(fā)和J2EE的區(qū)別07-07

    PHP中MySQL、MySQLi和PDO的用法和區(qū)別07-01

    linux命令中su和sudo區(qū)別08-10

    跆拳道中WTF和ITF的區(qū)別05-21

    在Java中執(zhí)行JavaScript代碼07-14

    Java中的動態(tài)代碼編程06-27

    速錄和打字的區(qū)別10-08

    爽膚水和柔膚水的區(qū)別05-07

    赤豆和紅豆的區(qū)別07-26

    主站蜘蛛池模板: 热久久国产精品| 亚洲欧洲自拍拍偷精品 美利坚| 精品国产婷婷久久久| 国产精品无码a∨精品| 日本精品一区二区三区在线视频| 日本精品中文字幕| 国产成人精品手机在线观看| 日韩精品人妻av一区二区三区| 国产精品视频九九九| 亚洲精品电影网| 精品国产第1页| 国产亚洲精品精华液| 亚洲精品~无码抽插| 日韩欧美一区二区三区中文精品| 国产精品成人观看视频网站| 久久九九青青国产精品| 成人国产精品免费视频| 蜜臀久久99精品久久久久久小说| 亚洲国产精品嫩草影院久久| 麻豆精品国产自产在线观看一区| 国产精品午夜一级毛片密呀| 国产精品成人无码久久久久久| 99精品国产成人一区二区| 99久久精品午夜一区二区| 欧美精品一区二区在线精品| 精品偷自拍另类在线观看丰满白嫩大屁股ass| 精品国产免费一区二区三区香蕉 | 无码精品A∨在线观看| 一本一道久久a久久精品综合| 完整观看高清秒播国内外精品资源| 久久精品视屏| 欧洲精品一区二区三区在线观看 | 亚洲精品网站在线观看不卡无广告| 拍国产真实乱人偷精品| 亚洲无码日韩精品第一页| 亚洲精品国产精品乱码不卡| 亚州日韩精品专区久久久| 亚洲精品偷拍视频免费观看| 亚洲中文字幕无码久久精品1| 亚洲国产精品福利片在线观看| 日韩精品久久久久久久电影蜜臀|