新聞中心
capacity(): 表明緩沖區(qū)的容量大小, 一旦確定了大小, 將不能再改變;
limit(): 告訴您到目前為止已經(jīng)往緩沖區(qū)填了多少字節(jié),或者用#limit(int)來改變這個限制;
position(): 告訴您當前的位置,以執(zhí)行下一個讀/寫操作;
mark(): 為了稍后用 reset() 進行重新設置而記住某個位置;
flip(): 交換限制指針和位置指針,然后將位置置為 0,并廢棄已經(jīng)做的mark標記。

為運河等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及運河網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為網(wǎng)站設計制作、成都網(wǎng)站設計、運河網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
緩沖區(qū)的基本操作是讀#get()和寫#put()。
緩沖區(qū)類型:
NIO具有7種特定的 Buffer 類型,每種類型對應著一個基本數(shù)據(jù)類型(除了 boolean)
- ByteBuffer //字節(jié)緩沖區(qū)
- CharBuffer //字符緩沖區(qū)
- DoubleBuffer //double 緩沖區(qū)
- FloatBuffer //float 緩沖區(qū)
- IntBuffer //int 緩沖區(qū)
- LongBuffer //long 緩沖區(qū)
- ShortBuffer //short 緩沖區(qū)
緩沖區(qū)分為直接緩沖區(qū)和間接緩沖區(qū),直接緩沖區(qū)的創(chuàng)建成本要高于間接緩沖區(qū),但同時它也會提供更快的I/O訪問速度。所以直接緩沖區(qū)適合那種長期存在的緩沖區(qū),而間接緩沖區(qū)則適合于生命周期較短的。還有,要注意,只有ByteBuffer可以創(chuàng)建直接緩沖區(qū)。
緩沖區(qū)的幾個內(nèi)部狀態(tài)的改變:
容量(capacity),緩沖區(qū)大小
限制(limit),***個不應被讀取或寫入的字節(jié)的索引,總是小于容量。
位置(position),下一個被讀取或寫入的字節(jié)的索引,總是小于限制。
0 <= position <= limit <= capacity
1. clear()方法:設置limit為capacity,position為0,并丟棄mark。
2. filp()方法:設置limit為當前position,然后設置position為0,并丟棄mark。
3. rewind()方法:保持limit不變,設置position為0,并丟棄mark。
原文鏈接:http://zddava.iteye.com/blog/315826
網(wǎng)頁題目:java.nio.Buffer的一些基礎知識的備忘
鏈接分享:http://www.dlmjj.cn/article/djeogeo.html


咨詢
建站咨詢
