ByteBuffer位于jdk源码包java.nio中
通过对该源码文件的注释的阅读可知该ByteBuffer具有如下的特点:
1、该buffer可以使用直接内存(操作系统内存,不受java虚拟机管理)和间接内存(jdk管理的内存,受java虚拟机管理)
PS(关于直接内存和间接内存的好处,网上搜索会出现很多,结论是直接内存比间接内存的I/O效率高,这仅限于在该buffer上有I/O操作,否则最好是使用间接内存,因为直接内存不受虚拟机管理,容易出现内存泄漏,那为什么说直接内存的I/O效率要比间接内存高呢?这是因为直接内存是操作系统管理的内存,I/O操作时属于操作系统的,所以I/O操作可以直接在该块内存上操作,然而间接内存是java虚拟机管理的,该块内存在操作系统上的位置不可知[–如果java虚拟机能找到该内存在操作系统上的内存地址,也可以达到直接内存的效果–],所以I/O操作无法直接操作,需要java虚拟机将该块内存拷贝到操作系统内存中,并把拷贝之后的地址交由I/O操作处理,所以这就是网上说的间接内存的I/O效率低下的原因)
从源码可以看出,直接内存是调用unsafe接口进行内存的分配,而间接内存是直接new的一个字节数组。
2、buffer视图
这个概念到底是什么意思呢,网上也有很多说明,但是个人推荐直接查看jdk源码的文档。
举一个例子就能很好的明白buffer视图的概念了
buffer的内容:公司的所有员工[小王,小张,小刘…]
buffer部分视图:公司的部门[A部门{小王},B部门{小刘}…]
从C语言的角度来说,同一部分字节,根据不同的数据类型,解析为不同的值,Union就是一个视图的体现。
3、可以自定义字节序(大端小端)