Vincent.Chan‘s Blog

          常用鏈接

          統(tǒng)計(jì)

          積分與排名

          網(wǎng)站

          最新評(píng)論

          [Jakarta Commons筆記] Commons Collections - Buffer組

          來看Buffer組。

           

          Buffer

          BlockingBuffer

          BoundedFifoBuffer

          PriorityBuffer

          UnboundedFifoBuffer

          BufferUtils

           

          Buffer是定義在org.apache.commons.collections包下面的接口,用于表示按一定順序除去成員對(duì)象的collection如隊(duì)列等。具體的實(shí)現(xiàn)類在org.apache.commons.collections.buffer包下可以找到。

           

          BufferUtils提供很多靜態(tài)/工具方法裝飾現(xiàn)有的Buffer實(shí)例,如將其裝飾成BlockingBuffer、執(zhí)行類型檢查的TypedBuffer、或者不可改變的UnmodifiableBuffer等等。

           

          最簡單直接的Buffer實(shí)現(xiàn)類是UnboundedFifoBuffer,提供先進(jìn)先出的大小可變的隊(duì)列。而BoundedFifoBuffer則是對(duì)其大小進(jìn)行了限制,是固定大小的先進(jìn)先出隊(duì)列。BlockingBuffer要在多線程的環(huán)境中才能體現(xiàn)出它的價(jià)值,尤其是當(dāng)我們需要實(shí)現(xiàn)某種流水線時(shí)這個(gè)BlockingBuffer很有用:每個(gè)流水線上的組件從上游的BlockingBuffer獲取數(shù)據(jù),處理后放到下一個(gè)BlockingBuffer中依次傳遞。BlockingBuffer的核心特色通俗點(diǎn)說就是如果你向它要東西,而它暫時(shí)還沒有的話,你可以一直等待直至拿到為止。PriorityBuffer則提供比一般的先進(jìn)先出Buffer更強(qiáng)的控制力:我們可以自定義Comparator給它,告訴它怎么判定它的成員的先后順序,優(yōu)先級(jí)最高的最先走。

           

          為了方便和清晰的需要,我在這里只舉一個(gè)BoundedFifoBuffer,包裝成TypedBuffer,看看在具體的代碼中通常如何使用Buffer:(還是沿用上次的Book類)

           

          package sean.study.commons.collections;

           

          import java.util.Iterator;

           

          import org.apache.commons.collections.Buffer;

          import org.apache.commons.collections.BufferUtils;

          import org.apache.commons.collections.buffer.BoundedFifoBuffer;

          import org.apache.commons.lang.StringUtils;

           

          public class BufferUsage {

           

              public static void main(String[] args) {

                  demoBufferUsage();

              }

           

              public static void demoBufferUsage() {

           

                  System.out.println(StringUtils.center(" demoBagUsage ", 40, "="));

           

                  // data setup

                  Book book1 = new Book("Refactoring Workbook", "7-5083-2208-8", 29.8);

                  Book book2 = new Book("J2EE Design Patterns", "7-5083-3099-4", 45);

                  Book book3 = new Book("Agile Software Development", "7-5083-1503-0", 59);

                  Book book4 = new Book("Professional JSP", "7-5053-8005-2", 100);

           

                  // create a Buffer

                  Buffer buffer =

                      BufferUtils.typedBuffer(new BoundedFifoBuffer(3), Book.class);

                  buffer.add(book1);

                  buffer.add(book2);

                  buffer.add(book3);

                  Book removed = (Book) buffer.remove();

                  System.out.println("Removed:");

                  System.out.println(removed);

                  buffer.add(book4);

                 

                  // get items in buffer

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

                      System.out.println(buffer.get());

                      buffer.remove();

                  }

           

                  System.out.println(StringUtils.repeat("=", 40));

           

              }

           

          }

           

          以下是運(yùn)行結(jié)果:

           

          ============= demoBagUsage =============

          Removed:

          sean.study.commons.collections.Book@e09713[

            name=Refactoring Workbook

            ISBN=7-5083-2208-8

            retailPrice=29.8

          ]

          Remaining:

          sean.study.commons.collections.Book@e09713[

            name=J2EE Design Patterns

            ISBN=7-5083-3099-4

            retailPrice=45.0

          ]

          sean.study.commons.collections.Book@47b480[

            name=Agile Software Development

            ISBN=7-5083-1503-0

            retailPrice=59.0

          ]

          sean.study.commons.collections.Book@19b49e6[

            name=Professional JSP

            ISBN=7-5053-8005-2

            retailPrice=100.0

          ]

          ========================================

           

          我們可以看到,Bufferaddremove方法分別添加新成員和刪除最先加入的成員。由于我們的Buffer定義為只能裝3個(gè)Book類的實(shí)例,所以不論我們?cè)噲D加入其他類型的對(duì)象,或者加入超過3個(gè),操作都將失敗。如果我們?cè)诒闅v時(shí)使用get()而不調(diào)用remove(),那么我們將得到3個(gè)相同的拷貝,而這正是我們期望的FIFO隊(duì)列的行為。假如你需要遍歷并保留數(shù)據(jù),可以使用標(biāo)準(zhǔn)的Iterator機(jī)制。

           

          posted on 2006-03-10 23:12 Vincent.Chen 閱讀(222) 評(píng)論(0)  編輯  收藏 所屬分類: Java

          主站蜘蛛池模板: 石首市| 五台县| 城步| 洛浦县| 松阳县| 德令哈市| 孝义市| 剑阁县| 神农架林区| 景德镇市| 襄汾县| 弋阳县| 赫章县| 曲阳县| 东辽县| 仪陇县| 宜宾县| 南充市| 沁阳市| 顺昌县| 江源县| 同德县| 昌江| 家居| 霍城县| 轮台县| 潢川县| 宜城市| 扬中市| 乳源| 开封市| 五寨县| 恩施市| 健康| 衡阳县| 安塞县| 兴安盟| 固始县| 宁明县| 宁强县| 云南省|