ByteBuffer小结

前言

在阅读源码的过程中,发现比较多的使用到了bytebuffer,但是由于之前没有接触过,所以现做以总结,以备复习。

ByteBuffer类位于java.nio包下,所谓nio:代表new io,另一种解释:N代表Non-blocking IO,非阻塞的IO。其中区别如下:

Java NIO和IO的主要区别

表格简单区别

面向流和缓冲型

Java NIO和IO第一个大的不同点是IO是面向流的,NIO则是缓冲型的。那么,这到底是什么意思?
Java IO是面向流的意味着我们从一个流中一次读取一个或多个字节。而要对读到的字节作何处理由我们自己决定;这其中没有任何缓存。此外,我们不能在数据流中来回移动;如果想要在从流读取的数据中来回移动,我们需要首先将数据缓存到缓冲区。
Java NIO的缓冲型方法稍有不同。数据读取到缓冲区后被加工,我们可以根据需求在数据中来回移动。这为处理提供了灵活性;然而为了充分处理所有数据我们还需要检查缓冲区是否包含所有需要的数据,并且我们需要确保读取更多数据到缓冲区时未被处理的数据不能被覆盖。

阻塞型IO和非阻塞型IO

Java IO的各种流是阻塞型的。这意味着,当一个线程调用read()方法或write()方法时这个线程将一直被阻塞,直到有数据被读到或者数据被完全写入;在被阻塞的同时,该线程不能做任何其他事情。
Java NIO的非阻塞模式允许一个线程从一个channel中请求读取数据,这只会取到当前有效的数据或当前没有数据有效时获取不到任何数据;而不是一直阻塞直到所读取数据准备好为止;在这同时该线程可以做其他事情。
这个过程对非阻塞式数据写入也是成立的。一个线程可以写入一些数据到channel,但是不用等待数据被完全写入。该线程在请求完成后可以继续同时去做其他事情。
当线程不在IO调用上被阻塞时,那么它们的空闲时间通常都花在了在其他channel上执行IO操作。也就是说,一个线程可以管理多个输入和输出的channel。

选择器(Selectors)

Java NIO中的selector允许一个线程监视多个channel的输入。我们可以在一个selector上注册多个channel,然后使用一个线程来 “选择”输入可用的channel来处理,或者选择准备好写入的channel。这种选择器模式使单个线程管理多个channel变的非常容易。

NIO和IO对应用设计的影响

不论我们选择NIO还是IO作为我们的IO工具包都可能在以下几方面影响应用的设计:

  • NIO或IO API类的调用
  • 数据的处理
  • 用于处理数据的线程数量

参考连接:Java NIO与IO

bytebuffer 使用

关于buffer的若干点

  • buffer是一个面向特定原始数据类型的容器;

  • 包含三个属性:capacity,limit和position,分别对应的是:缓存的容量,读取数据的限制和读取数据的位置;

    • capacity:分配好的内存块大小,分配好后大小不可修改;
    • limit:在读模式下,表示缓存的内数据大小;写模式下,表示最多可以存入数据大小,此时和capacity值相等;
    • position:表示读写的位置,下表从0开始;
  • making和resetting:对应标记和恢复;

      0 <= mark <= position <= limit <= capacity
    
  • clear(),flip(),rewind()方法:

    • clear:重新写入数据使用,将当前可用的第一个位置指向了buffer的首位值;
    • flip:用于读取buffer中的数据,将position置为0;
    • rewind:limit不变,position =0 ,指向了第一个位置处,用于重新读取;
  • hasRemaining()和remaining()

    • hasRemaining() ---是否还有可用的空间
    • remaining() ----查看还有多少可用的空间

常用API

  • allocate(int capacity): 分配一个新的字节缓冲区
  • get():相对 get 方法
  • get(int index) : 绝对 get 方法
  • getInt(): 用于读取 int 值的相对 get 方法
  • put(byte b): 相对 put 方法(可选操作)

代码演示

  • 读取字节

      public class TestBuffer {
          public static void main(String[] args) throws Exception {
              ByteBuffer bb = ByteBuffer.allocate(48);
              String str = "ceshiwenjianneirong...";
              byte[] tmp = str.getBytes();
              System.out.println(bb.toString());
              bb.put(tmp);
              // 从写模式切换到读模式
              bb.flip();  
              System.out.println(bb.toString());
              System.out.println((char)bb.get() + "===");     
          }
      }
    
  • 读取整形

      public class TestBuffer {
          public static void main(String[] args) throws Exception {
              ByteBuffer bb = ByteBuffer.allocate(48);
              System.out.println(bb.toString());
              bb.putInt(12345645);
              // 从写模式切换到读模式
              bb.flip();  
              System.out.println(bb.toString());
              System.out.println(bb.getInt() + "===");        
          }
      }
    
  • 代码说明:

    • bb.toString():toString() : 返回汇总了此缓冲区状态的字符串。
  • 输出结果:

      java.nio.HeapByteBuffer[pos=0 lim=48 cap=48]
      java.nio.HeapByteBuffer[pos=0 lim=4 cap=48]
      12345645===
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354

推荐阅读更多精彩内容

  • 转自 http://www.ibm.com/developerworks/cn/education/java/j-...
    抓兔子的猫阅读 2,305评论 0 22
  • Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java I...
    JackChen1024阅读 7,555评论 1 143
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,246评论 11 349
  • java nio Java的IO体系:旧IO新IO:nio,用ByteBuffer和FileChannel读写ni...
    则不达阅读 839评论 0 2
  • 写在开始之前 一直以来,总是不间断的有人问我:“我想学编程,有什么好的资源可以推荐的吗?” 我也不知道具体应该怎么...
    Airing阅读 283评论 2 1