java_66666 2017-10-24 09:41 采纳率: 0%
浏览 798

单个JVM进程也能利用机器超大内存

最近看到一个rocketmq的图片,其中有不经过java的heap直接从内存读数据到socket的描述,这用的是jvm的特性吗?
图片说明

  • 写回答

1条回答 默认 最新

  • yizishou 2017-11-10 04:16
    关注

    这是Java NIO的特性。

    通过管道传输数据,而不是通过流,这样可以避免数据在Java堆中的拷贝,提高效率。

    这样说吧,你可以将磁盘上的文件看做一个管道,而将网卡看做另外一个管道,通过Java代码直接控制这两个管道接通,之后的数据传输则自发进行。

    如果是使用数据流,那么你需要将文件内容读入Java堆,然后将堆中数据写入网卡,数据在Java堆中的进出是消耗时间的。

    如果你想关注这方面的东西,可以了解一下这些关键字:零拷贝、Linux管道

    评论

报告相同问题?

悬赏问题

  • ¥15 vue3项目使用router构建多个页面,页面跳转时不刷新就显示空白
  • ¥20 针对计算后数据做一致性检验可以用Bland Altman法吗
  • ¥15 win32如何自绘编辑框的背景图片(语言-c++|操作系统-windows)
  • ¥15 微信夜间被转走了1w对,当天手机剪切板里就出现了这个乱码,有铁子可以看看是啥吗可以
  • ¥50 跑通github上的代码 深度学习 pytorch
  • ¥50 求写,批处理调用分区助手分区脚本
  • ¥15 求购HI3519AV100开发板
  • ¥15 请问1553 RT怎么测试,没有BC有方法吗
  • ¥15 wamp3.3.5安装完成后图标正常显示绿色,鼠标左右键点击图标均无反应。求解决方法。
  • ¥15 鼠标点击的这条记录了什么?