博客
关于我
java堆内堆外内存困惑
阅读量:802 次
发布时间:2023-01-29

本文共 452 字,大约阅读时间需要 1 分钟。

理解操作系统中的IO机制对于优化Java程序性能非常重要,尤其是考虑到JVM的内存管理特性。以下是优化后的总结:

操作系统IO主要有直接IO和缓存IO两种类型。各语言中,IO处理不同。Linux默认使用缓存IO,导致Java程序比C/C++多一次内存拷贝,这影响了性能。

某些关键点:

  • 直接IO和缓存IO:直接IO直接读写设备,缓存IO记录数据到内核缓存,减少磁盘操作次数。

  • Java中的IO机制:JVM作为用户进程,分堆内和堆外空间。堆外使用操作系统缓存IO,同时需要考虑内存移动带来的额外拷贝,这影响了Java的IO性能。

代码解读:

FileChannelImpl的写方法使用同步块,完成文件操作,涉及文件描述符fd和IOUtil的帮助类。

IOUtil的写方法根据数据类型选择是否拷贝:直接内存无需拷贝,否则将数据拷贝到临时buffer,再写入操作系统缓存。

后续思考:

了解JVM如何处理内存拷贝和垃圾回收是改进Java程序性能的关键。结合具体JVM实现,进一步优化数据传输流程,避免性能瓶颈。

转载地址:http://doryk.baihongyu.com/

你可能感兴趣的文章
NN&DL4.7 Parameters vs Hyperparameters
查看>>
NN&DL4.8 What does this have to do with the brain?
查看>>
nnU-Net 终极指南
查看>>
No 'Access-Control-Allow-Origin' header is present on the requested resource.
查看>>
No 'Access-Control-Allow-Origin' header is present on the requested resource.
查看>>
NO 157 去掉禅道访问地址中的zentao
查看>>
no available service ‘default‘ found, please make sure registry config corre seata
查看>>
No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK?
查看>>
no connection could be made because the target machine actively refused it.问题解决
查看>>
No Datastore Session bound to thread, and configuration does not allow creation of non-transactional
查看>>
No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
查看>>
No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalanc
查看>>
No mapping found for HTTP request with URI [/...] in DispatcherServlet with name ...的解决方法
查看>>
No mapping found for HTTP request with URI [/logout.do] in DispatcherServlet with name 'springmvc'
查看>>
No module named 'crispy_forms'等使用pycharm开发
查看>>
No module named 'pandads'
查看>>
No module named cv2
查看>>
No module named tensorboard.main在安装tensorboardX的时候遇到的问题
查看>>
No module named ‘MySQLdb‘错误解决No module named ‘MySQLdb‘错误解决
查看>>
No new migrations found. Your system is up-to-date.
查看>>