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

湖北荆门建设银行网站织梦网站栏目管理

湖北荆门建设银行网站,织梦网站栏目管理,wordpress 娱乐插件,f型网站这里是小奏,觉得文章不错可以关注公众号小奏技术 背景 java nio中文件读写不管是普通文件读写#xff0c;还是基于mmap实现零拷贝#xff0c;都离不开FileChannel这个类。 随便打开RocketMQ 源码搜索FileChannel 就可以看到使用频率 kafka也是 所以在java中文件读写FileCh… 这里是小奏,觉得文章不错可以关注公众号小奏技术 背景 java nio中文件读写不管是普通文件读写还是基于mmap实现零拷贝都离不开FileChannel这个类。 随便打开RocketMQ 源码搜索FileChannel 就可以看到使用频率 kafka也是 所以在java中文件读写FileChannel尤为重用 java文件读写全流程 这里说的仅仅是FileChannel基于堆内存(HeapByteBuffer)的文件读写。 如果是mmap或者堆外内存可能有些步骤会省略相当于有一些优化 FileChannel调用read将HeapByteBuffer拷贝到DirectByteBufferJVM在native层使用read系统调用进行文件读取, 这里需要进行上下文切换从用户态进入内核态JVM 进程进入虚拟文件系统层,查看文件数据再page cache是否缓存如果有则直接从page cache读取并返回到DirectByteBuffer如果请求文件数据不在page caceh则进入文件系统。通过块驱动设备进行真正的IO并进行文件预读比如读取的文件可能只有1-10但是会将1-20都读取磁盘控制器DMA将磁盘中的数据拷贝到page cache中。这里发生了一次数据拷贝(非CPU拷贝)CPU将page cache数据拷贝到DirectByteBuffer因为page cache属于内核空间JVM进程无法直接寻址。这里是发生第二次数据拷贝JVM进程从内核态切换回用户态这里如果使用的是堆内存(HeapByteBuffer),实际还需要将堆外内存DirectByteBuffer拷贝到堆内存(HeapByteBuffer) FileChannel读写文件(非MMAP) public static void main(String[] args) {String filename 小奏技术.txt;String content Hello, 小奏技术.;// 写入文件writeFile(filename, content);// 读取文件System.out.println(Reading from file:);readFile(filename);}public static void writeFile(String filename, String content) {// 创建文件对象File file new File(filename);// 确保文件存在if (!file.exists()) {try {boolean created file.createNewFile();if (!created) {System.err.println(Unable to create file: filename);return;}} catch (Exception e) {System.err.println(An error occurred while creating the file: e.getMessage());return;}}// 使用FileChannel写入文件try (RandomAccessFile randomAccessFile new RandomAccessFile(file, rw);FileChannel fileChannel randomAccessFile.getChannel()) {ByteBuffer buffer ByteBuffer.allocate(content.getBytes().length);buffer.put(content.getBytes());buffer.flip(); // 切换到读模式while (buffer.hasRemaining()) {fileChannel.write(buffer);}} catch (Exception e) {System.err.println(An error occurred while writing to the file: e.getMessage());}}public static void readFile(String filename) {// 使用FileChannel读取文件try (RandomAccessFile randomAccessFile new RandomAccessFile(filename, r);FileChannel fileChannel randomAccessFile.getChannel()) {ByteBuffer buffer ByteBuffer.allocate((int) fileChannel.size());while (fileChannel.read(buffer) 0) {// Do nothing, just read}// 切换到读模式buffer.flip(); /* while (buffer.hasRemaining()) {System.out.print((char) buffer.get());}*/Charset charset StandardCharsets.UTF_8; String fileContent charset.decode(buffer).toString();System.out.print(fileContent);} catch (Exception e) {System.err.println(An error occurred while reading the file: e.getMessage());}} 这里需要注意的一个细节 我们分配的内存的方式是 ByteBuffer.allocate()这里我们可以进入看看源码 实际构造的是HeapByteBuffer也就是JVM的堆内存 如果我们使用 ByteBuffer.allocateDirect()则构造的是堆外内存DirectByteBuffer HeapByteBuffer和DirectByteBuffer文件读写区别 我们看看FileChannel read方法 发现IO相关的处理被封装在IOUtil 我们继续看看IOUtil的write方法 可以看到如果是DirectBuffer则可以直接写 如果是HeapByteBuffer则需要转换为DirectByteBuffer 为什么要在DirectByteBuffer做一层转换 主要是HeapByteBuffer受JVM管理也就是会受到GC影响 如果在进行native调用的时候发生了GC会导致HeapByteBuffer的内容出现错误 具体详细的说明可以看看这篇MappedByteBuffer VS FileChannel从内核层面对比两者的性能差异 讲解的非常清晰 参考 MappedByteBuffer VS FileChannel从内核层面对比两者的性能差异
http://www.w-s-a.com/news/596546/

相关文章:

  • 有什么做糕点的视频网站黄岛做网站
  • 做视频课程网站建设一个普通网站需要多少钱
  • 专做化妆品的网站合肥做网站建设公司
  • 唐山企业网站网站建设费计入那个科目
  • 企业网站制作运营彩虹云主机官网
  • 如何建设废品网站如何在阿里云云服务器上搭建网站
  • 如何建立网站后台程序wordpress 后台管理
  • 山东外贸网站建设怎么样wordpress首页左图右文
  • 志丹网站建设wordpress 形式修改
  • 南通seo网站推广费用网站建设就业前景
  • 自适应网站做mip改造浏览器广告投放
  • 网站meta网页描述网站的推广费用
  • 偃师市住房和城乡建设局网站网站个人主页怎么做
  • 做网站要实名认证吗wordpress去掉仪表盘
  • 在哪做网站好Python建网站的步骤
  • 卢松松的网站办公室设计布局
  • 住房城乡建设干部学院网站织梦网站0day漏洞
  • 企业网站seo优帮云手机桌面布局设计软件
  • 无证做音频网站违法吗智能建站加盟电话
  • 鹿泉专业网站建设做网站为什么要建站点
  • 加强网站建设和维护工作新闻大全
  • 红鱼洞水库建设管理局网站左右左布局网站建设
  • 手机网站建设地址做网站公
  • 贵州建设厅网站首页网络公司除了做网站
  • 运动鞋建设网站前的市场分析wordpress 搜索框代码
  • app开发网站开发教程平台网站开发的税率
  • 百度网站优化排名加强服务保障满足群众急需i
  • 宁夏建设职业技术学院网站安徽网站优化建设
  • 四川关于工程建设网站硬盘做网站空间
  • 桂林网站制作培训学校外包seo公司