欢迎来到天天文库
浏览记录
ID:36198276
大小:1.50 MB
页数:26页
时间:2019-05-07
《jvm原理及内存溢出经典案列分析》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、JVM原理及内存溢出经典案列分析目录结构目录JVM基本概念JVM原理内存溢出现象内存溢出分析附录JVM基本概念JVM管理java中的内存java虚拟机自己去管理的,他不想C++需要自己去释放。笼统地去讲,java的内存分配分为两个部分,一个是数据堆,一个是栈。程序在运行的时候一般分配数据堆,把局部的临时的变量都放进去,生命周期和进程有关系。但是如果程序员声明了static的变量,就直接在栈中运行的,进程销毁了,不一定会销毁static变量。垃圾回收机制关键为了保证java内存不会溢出,java中有垃圾回收机制。System.gc()即垃圾
2、收集机制是指jvm用于释放那些不再使用的对象所占用的内存。java语言并不要求jvm有gc,也没有规定gc如何工作。垃圾收集的目的在于清除不再使用的对象。gc通过确定对象是否被活动对象引用来确定是否收集该对象JVM基本概念内存溢出和泄露内存溢出就是你要求分配的java虚拟机内存超出了系统能给你的,系统不能满足需求,于是产生溢出内存泄漏是指你向系统申请分配内存进行使用(new),可是使用完了以后却不归还(delete),结果你申请到的那块内存你自己也不能再访问,该块已分配出来的内存也无法再使用,随着服务器内存的不断消耗,而无法使用的内存越来
3、越多,系统也不能再次将它分配给需要的程序,产生泄露。一直下去,程序也逐渐无内存使用,就会溢出。JVM原理内存区划分◇栈内存(Stack):每个线程私有的。◇堆内存(Heap):所有线程公用的。◇方法区(MethodArea):有点像以前常说的“进程代码段”,这里面存放了每个加载类的反射信息、类函数的代码、编译时常量等信息。◇原生方法栈(NativeMethodStack):主要用于JNI中的原生代码,平时很少涉及。JVM原理JVM分代总结:EdenSpace(heap):内存最初从这个线程池分配给大部分对象。SurvivorSpace(h
4、eap):用于保存在edenspace内存池中经过垃圾回收后没有被回收的对象。TenuredGeneration(heap):用于保持已经在survivorspace内存池中存在了一段时间的对象。PermanentGeneration(non-heap):保存虚拟机自己的静态(refective)数据,例如类(class)和方法(method)对象。Java虚拟机共享这些类数据。这个区域被分割为只读的和只写的。CodeCache(non-heap):HotSpotJava虚拟机包括一个用于编译和保存本地代码(nativecode)的内存,
5、叫做“代码缓存区”(codecache)。JVM原理JVM分代JVM定义了两个代,年轻代(yonggeneration)(有时称为“nursery”托儿所)和老年代(oldgeneration)。年轻代包括“Edenspace(伊甸园)”和两个“survivorspaces”。虚拟内存初始化的时候会把所有对象都分配到Edenspace,并且大部分对象也会在该区域被释放。当进行minorGC的时候,VM会把剩下的没有释放的对象从Edenspace移动到其中一个survivorspaces当中。此外,VM也会把那些长期存活在survivors
6、paces里的对象移动到老生代的“tenured”space中。当tenuredgeneration被填满后,就会产生FullGC,FullGC会相对比较慢因为回收的内容包括了所有的live状态的对象。pemanetgeneration这个代包括了所有java虚拟机自身使用的相对比较稳定的数据对象,比如类和对象方法等。JVM原理JVM收集方式一种称为copying或scavenge,将所有仍然生存的对象搬到另外一块内存后,整块内存就可回收。这种方法有效率,但需要有一定的空闲内存,拷贝也有开销。这种方法用于minorcollection。
7、另外一种称为majorcollectiont,将活着的对象标记出来,然后搬迁到一起连成大块的内存,其他内存就可以回收了。这种方法不需要占用额外的空间,但速度相对慢一些。JVM原理垃圾回收器Java的使用的是堆内存,java堆是一个运行时数据区,类的实例(对象)从中分配空间。Java虚拟机(JVM)的堆中储存着正在运行的应用程序所建立的所有对象,“垃圾回收”也是主要是和堆内存(Heap)有关。垃圾回收器的分代策略是把内存区划分为几个代,然后为每个代分配一到多个内存区块。当其中一个代用完了分配给他的内存后,JVM会在分配的内存区内执行一个
8、局部的GC(也可以叫minorcollection)操作,为了回收处于“dead”状态的对象所占用的内存。局部GC通常要不FullGC要快很多。JVM原理垃圾回收器垃圾回收的概念就是JAV
此文档下载收益归作者所有