在看Netty时,看到了一个词,“非堆内存”。 简单来说,堆内存就是heap, 非堆内存就是non-heap.
按照官方的说法:“Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配。堆是在 Java 虚拟机启动时创建的。”“在JVM中堆之外的内存称为非堆内存(Non-heap memory)”。可以看出JVM主要管理两种类型的内存:堆和非堆。简单来说堆就是Java代码可及的内存,是留给开发人员使用的;非堆就是JVM留给 自己用的,所以方法区、JVM内部处理或优化所需的内存(如JIT编译后的代码缓存)、每个类结构(如运行时常数池、字段和方法数据)以及方法和构造方法 的代码都在非堆内存中。
具体来说,Non-Heap Memory Pool包括:
1. Code Cache (non-heap):储存编译的程式码和local variables。
2. Permanent Generation(non-heap):包含虚拟机器自身的所有反射资料。 比如class和mothod物件。 对于使用class data sharing的JVM,分为唯读(shared-ro)和读写(shared-rw)两个区域。
现在的疑问是:Netty为什么用Non-Heap Memory呢?为什么用Non Heap Memory就能加快读取速度呢?
本文解释了Java虚拟机中的堆内存与非堆内存的区别,重点介绍了非堆内存的组成部分及其在Netty中的应用。文章探讨了为何Netty选择使用非堆内存来提升数据读取速度。
13万+

被折叠的 条评论
为什么被折叠?



