1. <tt id="5hhch"><source id="5hhch"></source></tt>
    1. <xmp id="5hhch"></xmp>

  2. <xmp id="5hhch"><rt id="5hhch"></rt></xmp>

    <rp id="5hhch"></rp>
        <dfn id="5hhch"></dfn>

      1. Java中Queue和BlockingQueue的區(qū)別

        時(shí)間:2022-06-06 05:12:42 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ì)列中沒有元素時(shí),稱為空隊(duì)列。下面小編準(zhǔn)備了關(guān)于Java中Queue和BlockingQueue的區(qū)別,提供給大家參考!

          1.BlockingQueue:支持兩個(gè)附加操作的 Queue,這兩個(gè)操作是:檢索元素時(shí)等待隊(duì)列變?yōu)榉强,以及存?chǔ)元素時(shí)等待空間變得可用。

          2.BlockingQueue 不接受 null 元素。

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

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

          根據(jù)Api修改的一個(gè)例子,大家可以修改自己體驗(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);

          }

          }

          /**

          * 一個(gè)生產(chǎn)者、兩個(gè)消費(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ū)別04-27

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

        跆拳道中WTF和ITF的區(qū)別11-01

        j2ee與java的區(qū)別04-01

        打工和創(chuàng)業(yè)的區(qū)別04-13

        PETS和CET的區(qū)別08-18

        戲曲和話劇的區(qū)別05-08

        自考和電大的區(qū)別09-04

        flash源文件中fla文件和swf文件有什么區(qū)別03-30

        白茶和老白茶的區(qū)別02-08

        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码

        1. <tt id="5hhch"><source id="5hhch"></source></tt>
          1. <xmp id="5hhch"></xmp>

        2. <xmp id="5hhch"><rt id="5hhch"></rt></xmp>

          <rp id="5hhch"></rp>
              <dfn id="5hhch"></dfn>