当前位置: 首页 > news >正文

网站如何设置404页面不用下载直接浏览的网站

网站如何设置404页面,不用下载直接浏览的网站,南宁网站建公司,wordpress 访问密码在 Java 网络编程和高性能 I/O 场景中,ByteBuffer 和 ByteBuf 是两种重要的缓冲区处理工具。ByteBuffer 是 Java NIO 标准库的一部分,而 ByteBuf 是由 Netty 框架提供的增强缓冲区工具。在实际开发中,选择哪一种取决于场景需求和性能目标。 …

在 Java 网络编程和高性能 I/O 场景中,ByteBufferByteBuf 是两种重要的缓冲区处理工具。ByteBuffer 是 Java NIO 标准库的一部分,而 ByteBuf 是由 Netty 框架提供的增强缓冲区工具。在实际开发中,选择哪一种取决于场景需求和性能目标。

1. 什么是 ByteBuffer?

ByteBuffer 是 Java NIO(New Input/Output)中的核心类,用于以缓冲区的形式处理数据。它可以高效地读取、写入和操作字节数据,广泛用于文件读写、网络传输等场景。

ByteBuffer 的主要特性

  • 固定容量:分配时指定固定大小,不能动态扩展。
  • 操作模式切换:读写操作需要在 读模式写模式 之间切换。
  • 提供基本的字节操作:支持直接操作字节或转换为特定数据类型(如 int、long 等)。
  • 堆内存和直接内存支持ByteBuffer 可分配在堆内存或直接内存中,4.1版本后默认是直接内存,可以调用不同方法进行切换。
  • // 直接内存
    ByteBuf directBuf = ByteBufAllocator.DEFAULT.directBuffer();
    // 堆内存
    ByteBuf heapBuf = ByteBufAllocator.DEFAULT.heapBuffer();
    

2. 什么是 ByteBuf?

ByteBuf 是由 Netty 框架引入的增强型缓冲区工具。它针对 ByteBuffer 的一些缺点进行了优化,使得缓冲区在高性能场景中更高效且更易用。

ByteBuf 的主要特性

  • 动态扩展:支持自动扩容,避免手动重新分配缓冲区。
  • 读写指针分离:读操作和写操作有独立的指针,无需切换模式。
  • 池化机制:内置内存池,优化了内存分配和回收效率。
  • 零拷贝:支持更高级的零拷贝功能(如 slice 和复合缓冲区)。
  • 引用计数:通过引用计数机制有效管理缓冲区生命周期,避免内存泄漏。

3. ByteBuffer 与 ByteBuf 的对比

下表总结了 ByteBufferByteBuf 的核心差异和各自的优缺点:

特性ByteBufferByteBuf
读写模式使用同一个指针,需要切换模式(flip()compact()读写指针分离,无需手动切换,操作更简单
扩容支持不支持动态扩容,需手动重新分配支持动态扩容,内存自动调整
池化机制无池化机制,每次分配都需要系统调用支持内存池化(PooledByteBufAllocator),效率更高
零拷贝支持基础的 slice()duplicate()提供高级零拷贝支持(slice、复合缓冲区等)
引用计数不支持引用计数,生命周期需开发者手动管理支持引用计数(retain()release()),自动内存回收
API 易用性操作模式复杂,需手动管理指针位置提供更丰富和直观的 API,适合高性能场景
内存分配支持堆内存和直接内存支持堆内存、直接内存,以及池化内存
适用场景简单的 I/O 操作或 Java 标准库高性能网络编程(特别是基于 Netty 的开发)

4. ByteBuf 的优势详解

4.1 读写指针分离

  • ByteBuffer 使用同一个指针来管理读写位置,需要调用 flip() 切换读写模式。这种操作容易出错且不直观。比如:

ByteBuffer buffer = ByteBuffer.allocate(10);
buffer.put((byte) 1);
buffer.flip(); // 切换到读模式
byte b = buffer.get();
buffer.compact(); // 再次切换到写模式

ByteBuf 使用独立的读指针和写指针,无需模式切换:

ByteBuf buf = Unpooled.buffer(10);
buf.writeByte(1); // 写数据
byte b = buf.readByte(); // 直接读取,无需模式切换

4.2 动态扩容

  • ByteBuffer 的容量固定,当容量不足时,必须手动扩展。例如:

ByteBuffer buffer = ByteBuffer.allocate(10);
buffer.put((byte) 1); // 容量满了需要手动重新分配
ByteBuffer newBuffer = ByteBuffer.allocate(20);
buffer.flip();
newBuffer.put(buffer);

ByteBuf 支持动态扩容(最大值是Int最大值Integer.MAX_VALUE),无需手动管理:

ByteBuf buf = Unpooled.buffer(10);
buf.writeBytes(new byte[15]); // 自动扩容

4.3 内存池化

  • ByteBuf 提供内置内存池(PooledByteBufAllocator),通过对象复用优化内存分配效率,降低垃圾回收频率。
  • 对于高并发、高频分配的场景,池化机制可以显著提升性能。
  • netty4.1之后默认开启池化,但是安卓默认是非池化。需要切换到非池化需要加启动参数:
  • -Dio.netty.allocator.type=unpooled

4.4 零拷贝

  • ByteBuf 提供更强大的零拷贝功能:
    • slice:创建子缓冲区,避免数据复制。
    • 复合缓冲区(CompositeByteBuf):通过逻辑组合多个物理缓冲区,避免拷贝。
    • 直接内存支持:减少 JVM 堆到操作系统内核的拷贝。

4.5 引用计数

  • ByteBuf 使用引用计数来管理内存,避免内存泄漏或重复释放:
ByteBuf buf = PooledByteBufAllocator.DEFAULT.buffer();
buf.retain(); // 增加引用计数
buf.release(); // 减少引用计数,当计数归零时内存自动回收

5. 适用场景

  • 使用 ByteBuffer 的场景

    • 需要轻量级的缓冲区操作。
    • 使用标准 Java 库开发(无需额外依赖)。
    • 数据量较小且性能要求不高。
  • 使用 ByteBuf 的场景

    • 高性能网络编程,例如 Netty 中的 HTTP 服务、RPC 框架等。
    • 需要频繁扩展缓冲区或并发操作。
    • 高吞吐量场景,例如处理大规模流式数据。
http://www.yayakq.cn/news/133322/

相关文章:

  • 如何做做网站哪个公司需要做网站
  • 天津市网站建设+网页制作wordpress获取登录权限
  • 最新开的手游传奇网站网站建设越来越注重用户体验
  • 模块网站开发工具用来网站备案注册什么公司好
  • 西安公司注册网站衡水建设局网站
  • 北京广告公司名录长沙网站优化对策
  • app门户网站营销型网站关键词多少为好
  • 旅游网站首页图片喷码机营销型网站
  • 网站建站工具有哪些南京市工程造价信息网
  • 如何创建网站 优帮云建站
  • 网站开发学校 优帮云商标注册官网入口官网
  • 莆田做网站卫计网站建设工作计划
  • 沈阳企业模板建站太原王建设
  • 多语种网站建设公司万国手表网站
  • html5静态网站哪些编程语言适合网站开发
  • 网站信息抽查评估thinkphp网站开发服务
  • 一个网站做各种好玩的实验网站开发人员需要什么要求
  • 质量好网站建设费用网站手机端页面怎么做
  • 广元市利州区建设局网站wordpress 5.2.2安装要求
  • 怎么用免费的网站空间易企秀怎么做招聘网站超链接
  • 哪些网站是做采购的西宁网站建设报价ew君博贴心
  • 技术教程优化搜索引擎整站中国化工建设协会网站
  • 做感恩网站的图片大全ydg wordpress theme
  • 做网站分为哪些功能的网站广告联盟怎么建设网站
  • 自己网站制作redis wordpress 设置密码
  • 淮安网站设计网站内容添加
  • 网站做违法的事情投诉wordpress文章添加标签居中
  • 网站后台插件江西南昌网站建设服务
  • 营销型网站的定义怎么做电商无货源模式
  • 做胃肠科网站莆田企业免费建站