首頁 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡課程 模擬考試 考友錄 實用文檔 求職招聘 論文下載
2011中考 | 2011高考 | 2012考研 | 考研培訓 | 在職研 | 自學考試 | 成人高考 | 法律碩士 | MBA考試
MPA考試 | 中科院
四六級 | 職稱英語 | 商務英語 | 公共英語 | 托福 | 雅思 | 專四專八 | 口譯筆譯 | 博思 | GRE GMAT
新概念英語 | 成人英語三級 | 申碩英語 | 攻碩英語 | 職稱日語 | 日語學習 | 法語 | 德語 | 韓語
計算機等級考試 | 軟件水平考試 | 職稱計算機 | 微軟認證 | 思科認證 | Oracle認證 | Linux認證
華為認證 | Java認證
公務員 | 報關員 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 期貨從業(yè)資格 | 司法考試 | 法律顧問 | 導游資格
報檢員 | 教師資格 | 社會工作者 | 外銷員 | 國際商務師 | 跟單員 | 單證員 | 物流師 | 價格鑒證師
人力資源 | 管理咨詢師考試 | 秘書資格 | 心理咨詢師考試 | 出版專業(yè)資格 | 廣告師職業(yè)水平
駕駛員 | 網(wǎng)絡編輯
衛(wèi)生資格 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 執(zhí)業(yè)護士
會計從業(yè)資格考試會計證) | 經(jīng)濟師 | 會計職稱 | 注冊會計師 | 審計師 | 注冊稅務師
注冊資產(chǎn)評估師 | 高級會計師 | ACCA | 統(tǒng)計師 | 精算師 | 理財規(guī)劃師 | 國際內(nèi)審師
一級建造師 | 二級建造師 | 造價工程師 | 造價員 | 咨詢工程師 | 監(jiān)理工程師 | 安全工程師
質(zhì)量工程師 | 物業(yè)管理師 | 招標師 | 結構工程師 | 建筑師 | 房地產(chǎn)估價師 | 土地估價師 | 巖土師
設備監(jiān)理師 | 房地產(chǎn)經(jīng)紀人 | 投資項目管理師 | 土地登記代理人 | 環(huán)境影響評價師 | 環(huán)保工程師
城市規(guī)劃師 | 公路監(jiān)理師 | 公路造價師 | 安全評價師 | 電氣工程師 | 注冊測繪師 | 注冊計量師
繽紛校園 | 實用文檔 | 英語學習 | 作文大全 | 求職招聘 | 論文下載 | 訪談 | 游戲
您現(xiàn)在的位置: 考試吧(Exam8.com) > 計算機等級考試 > 計算機二級 > JAVA > 復習資料 > 正文

2011年計算機等考二級JAVA學習精華整理(48)

來源:考試吧Exam8.com) 2010-11-23 9:35:39 考試吧:中國教育培訓第一門戶 模擬考場
考試吧整理了2011年計算機的等考二級JAVA學習精華,幫助考生備考。

  根據(jù)不同的需要BlockingQueue有4種具體實現(xiàn):

  ArrayBlockingQueue:規(guī)定大小的BlockingQueue,其構造函數(shù)必須帶一個int參數(shù)來指明其大小。其所含的對象是以FIFO(先入先出)順序排序的。

  LinkedBlockingQueue:大小不定的BlockingQueue,若其構造函數(shù)帶一個規(guī)定大小的參數(shù),生成的BlockingQueue有大小限制,若不帶大小參數(shù),所生成的BlockingQueue的大小由Integer.MAX_VALUE來決定。其所含的對象是以FIFO(先入先出)順序排序的。LinkedBlockingQueue和ArrayBlockingQueue比較起來,它們背后所用的數(shù)據(jù)結構不一樣,導致LinkedBlockingQueue的數(shù)據(jù)吞吐量要大于ArrayBlockingQueue,但在線程數(shù)量很大時其性能的可預見性低于ArrayBlockingQueue。

  PriorityBlockingQueue:類似于LinkedBlockingQueue,但其所含對象的排序不是FIFO,而是依據(jù)對象的自然排序順序或者是構造函數(shù)所帶的Comparator決定的順序。

  SynchronousQueue:特殊的BlockingQueue,對其的操作必須是放和取交替完成的。

  下面是用BlockingQueue來實現(xiàn)Producer和Consumer的例子:

  public class BlockingQueueTest {

  static BlockingQueue basket;

  public BlockingQueueTest() {

  //定義了一個大小為2的BlockingQueue,也可根據(jù)需要用其他的具體類

  basket = new ArrayBlockingQueue(2);

  }

  class Producor implements Runnable {

  public void run() {

  while(true){

  try {

  //放入一個對象,若basket滿了,等到basket有位置

  basket.put("An apple");

  } catch (InterruptedException ex) {

  ex.printStackTrace();

  }

  }

  }

  }

  class Consumer implements Runnable {

  public void run() {

  while(true){

  try {

  //取出一個對象,若basket為空,等到basket有東西為止

  String result = basket.take();

  } catch (InterruptedException ex) {

  ex.printStackTrace();

  }

  }

  }

  }

  public void execute(){

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

  new Thread(new Producor()).start();

  new Thread(new Consumer()).start();

  }

  }

  public static void main(String[] args){

  BlockingQueueTest test = new BlockingQueueTest();

  test.execute();

  }

  }

  7:Atomics 原子級變量

  原子量級的變量,主要的類有AtomicBoolean, AtomicInteger, AotmicIntegerArray, AtomicLong, AtomicLongArray, AtomicReference ……。這些原子量級的變量主要提供兩個方法:

  compareAndSet(expectedValue, newValue): 比較當前的值是否等于expectedValue,若等于把當前值改成newValue,并返回true。若不等,返回false。

  getAndSet(newValue): 把當前值改為newValue,并返回改變前的值。

  這些原子級變量利用了現(xiàn)代處理器(CPU)的硬件支持可把兩步操作合為一步的功能,避免了不必要的鎖定,提高了程序的運行效率。

  8:Concurrent Collections 共點聚集

  在Java的聚集框架里可以調(diào)用Collections.synchronizeCollection(aCollection)將普通聚集改變成同步聚集,使之可用于多線程的環(huán)境下。 但同步聚集在一個時刻只允許一個線程訪問它,其它想同時訪問它的線程會被阻斷,導致程序運行效率不高。Java 5.0里提供了幾個共點聚集類,它們把以前需要幾步才能完成的操作合成一個原子量級的操作,這樣就可讓多個線程同時對聚集進行操作,避免了鎖定,從而提高了程序的運行效率。Java 5.0目前提供的共點聚集類有:ConcurrentHashMap, ConcurrentLinkedQueue, CopyOnWriteArrayList和CopyOnWriteArraySet.

上一頁  1 2 3 4 5 6 7 8 9 10  下一頁
  相關推薦:計算機等級考試二級Java經(jīng)典算法大全匯總

       2010年9月計算機等級考試成績查詢時間匯總

        2011計算機等級考試二級JAVA學習精華匯總

文章搜索
版權聲明:如果計算機等級考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權益,請與我們聯(lián)系800@exam8.com,我們將會及時處理。如轉(zhuǎn)載本計算機等級考試網(wǎng)內(nèi)容,請注明出處。