Netty的深入浅出--27.NIO的buffer绝对操作、allocate 方法和只读buffer

本文探讨了Buffer在项目中的应用,特别是在绝对操作下的截取与共享内存原理。详细解析了只读Buffer的实现机制,即在尝试修改时抛出异常,保持数据不变性。同时,揭示了只读Buffer与源Buffer之间的内存共享关系。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前几章的项目里面基本上使用的是相对操作,现在下面使用一些绝对操作:

我相信你们看了我之前几篇博客之后,到这不能理解只有slice()方法。

 创建一个新的buffer,也就是我们通过绝对操作截取出来的那段

 判断上面这两个buffer是不是独立的

运行:

结果从2开始到5发生了变化,说明他们两个buffer共享内存。

 创建只读buffer:

这里细讲一下allocate 

源码中ByteBuffer是一个抽象类,真正的对象创建是通过allocate()方法实现的

打印出各自的类名:

我们会疑惑,那它是怎么只读的呢?

 简单来说就是,在你put的时候直接给你抛出异常,如此简单粗暴o(* ̄︶ ̄*)o

我们在ByteBuffer里面找到put方法的重写方法

看见没,直接抛出异常 ,没有多余的操作Σ(⊙▽⊙"!

其实不只是它,很多只读方法都是采取这种方式抛出异常的

注意:

还得说明一点,只读buffer和源buffer共享的是通过一个buffer ,当源buffer改变的时候只读buffer的内容也会发现改变。

java.io.IOException: 远程主机强迫关闭了一个现有的连接。 at sun.nio.ch.SocketDispatcher.read0(Native Method) ~[na:1.8.0_442] at sun.nio.ch.SocketDispatcher.read(SocketDispatcher.java:43) ~[na:1.8.0_442] at sun.nio.ch.IOUtil.readIntoNativeBuffer(IOUtil.java:223) ~[na:1.8.0_442] at sun.nio.ch.IOUtil.read(IOUtil.java:192) ~[na:1.8.0_442] at sun.nio.ch.SocketChannelImpl.read(SocketChannelImpl.java:379) ~[na:1.8.0_442] at io.netty.buffer.PooledByteBuf.setBytes(PooledByteBuf.java:253) ~[netty-buffer-4.1.65.Final.jar:4.1.65.Final] at io.netty.buffer.AbstractByteBuf.writeBytes(AbstractByteBuf.java:1132) ~[netty-buffer-4.1.65.Final.jar:4.1.65.Final] at io.netty.channel.socket.nio.NioSocketChannel.doReadBytes(NioSocketChannel.java:350) ~[netty-transport-4.1.65.Final.jar:4.1.65.Final] at io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:151) ~[netty-transport-4.1.65.Final.jar:4.1.65.Final] at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:719) [netty-transport-4.1.65.Final.jar:4.1.65.Final] at io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:655) [netty-transport-4.1.65.Final.jar:4.1.65.Final] at io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:581) [netty-transport-4.1.65.Final.jar:4.1.65.Final] at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:493) [netty-transport-4.1.65.Final.jar:4.1.65.Final] at io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:989) [netty-common-4.1.65.Final.jar:4.1.65.Final] at io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74) [netty-common-4.1.65.Final.jar:4.1.65.Final] at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30) [netty-common-4.1.65.Final.jar:4.1.65.Final] at java.lang.Thread.run(Thread.java:750) [na:1.8.0_442] 2025-03-24 19:14:17.048 INFO 41924 --- [oEventLoop-4-11] i.l.core.protocol.ReconnectionHandler : Reconnect
最新发布
03-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值