简述java内存分配与回收策率有什么用?

Python020

简述java内存分配与回收策率有什么用?,第1张

引言:大多数情况下,对象在新生代Eden区中分配。当Eden区没有足够空间进行分配时,虚拟机将发起一次Minor GC。新生代GC(Minor GC):指发生在新生代的垃圾收集动作,因为Java对象大多都具备朝生夕灭的特性,所以Minor GC非常频繁,一般回收速度也比较快。老年代GC(Major GC / Full GC):指发生在老年代的GC,出现了Major GC,经常会伴有至少一次的Minor GC(但非绝对的,在Parallel Scavenge收集器的收集策略里就有直接进行Major GC的策略选择过程)。Major GC的速度一般会比Minor GC慢10倍以上。

一、内存分配

内存分配:1.栈区:栈可以分为Java虚拟机和本地方法栈。2.堆区域:堆由所有线程共享,并在虚拟机启动时创建。这是存储对象实例的唯一目的,也是gc的主要领域。一般可以分为年轻一代和老一代两大块。3.方法区:由所有线程共享,用于存储信息、常量、静态变量等。由虚拟机加载的。它是由Java虚拟机描述为堆的逻辑部分。习惯被称为永久一代。4.程序计数器:是当前线程执行的行号指示器,跳转指令等都依赖于这个完成,线程私有。

二、回收策略

回收策略和次要垃圾收集和主要垃圾收集(完整垃圾收集)1.对象优先分配在堆区的Eden区。2.大物件直接进入老年代。3.长期生存者直接进入老年代。回收:当Eden区域没有足够的空间分配时,虚拟机将执行Minor GC。未成年人GC一次,一般发生在Eden新生代,因为这个区域的物体寿命短,频率高,回收速度快。主要气相色谱发生在老年代。一般触发老年的GC不会触发Minor GC,但是通过配置,Minor GC之前可以执行一次,可以加快老年的恢复。

三、总结

可达性分析:以名为“GC根”的对象为起点,从这些节点向下搜索。当一个对象不能连接到“垃圾回收根”时,意味着它是可回收的。

基本类型的变量如果是临时变量,只要定义了,就会分配内存空间,不管是否被赋值;如果是作为对象的属性出现,只要该对象不实例化,就不会分配内存空间。\x0d\x0a\x0d\x0a一个完整的Java程序运行过程会涉及以下内存区域:\x0d\x0a1、寄存器:JVM内部虚拟寄存器,存取速度非常快,程序不可控制。\x0d\x0a2、 栈:保存局部变量的值,包括:\x0d\x0a1)用来保存基本数据类型的值;\x0d\x0a2)保存类的实例,即堆区对象的引用(指针)\x0d\x0a3)也可以用来保存加载方法时的帧\x0d\x0a3、堆:用来存放动态产生的数据,比如new出来的对象。注意创建出来的对象只包含属于各自的成员变量,并不包括成员方法。因为同一个类的对象拥有各自的成员变量,存储在各自的堆中,但是他们共享该类的方法,并不是每创建一个对象就把成员方法复制一次。\x0d\x0a\x0d\x0a4、常量池:JVM为每个已加载的类型维护一个常量池,常量池就是这个类型用到的常量的一个有序集合。包括直接常量(基本类型,String)和对其他类型、方法、字段的符号引用(1)。池中的数据和数组一样通过索引访问。由于常量池包含了一个类型所有的对其他类型、方法、字段的符号引用,所以常量池在Java的动态链接中起了核心作用。常量池存在于堆中。\x0d\x0a\x0d\x0a5、代码段:用来存放从硬盘上读取的源程序代码。\x0d\x0a6、数据段:用来存放static定义的静态成员。\x0d\x0a\x0d\x0a注意:\x0d\x0a 1.一个Java文件,只要有main入口方法,我们就认为这是一个Java程序,可以单独编译运行。\x0d\x0a 2.无论是普通类型的变量还是引用类型的变量(俗称实例),都可以作为局部变量,他们都可以出现在栈中。只不过普通类型的变量在栈中直接保存它所对应的值,而引用类型的变量保存的是一个指向堆区的指针,通过这个指针,就可以找到这个实例在堆区对应的对象。因此,普通类型变量只在栈区占用一块内存,而引用类型变量要在栈区和堆区各占一块内存。

Java把内存划分为以下4个部分:

1、栈区(stacksegment)—由编译器自动分配释放,存放函数的参数值,局部变量的值等,具体方法执行结束之后,系统自动释放JVM内存资源。

2、堆区(heapsegment)—一般由程序员分配释放,存放由new创建的对象和数组,jvm不定时查看这个对象,如果没有引用指向这个对象就回收。

3、静态区(datasegment)—存放全局变量,静态变量和字符串常量,不释放。

4、代码区(codesegment)—存放程序中方法的二进制代码,而且是多个对象共享一个代码空间区域。