很多对象有一个很短的生存期(比如迭代器iterators、本地变量)
某些对象拥有很长的生存期(比如高层持久化对象)
所以,分代的GC将内存划分为代(generations)并且赋予每一个内存池。当一代用尽了分配的内存,VM会在那个内存池进行一次局部 (partial)的垃圾收集(或者叫minor collection)来收集被死对象占用的内存。局部垃圾收集比全垃圾收集(full GC)快的多。
HotSpot VM定义了2代:young generation (有时叫做nursery)和old generation。Young generation由一个eden space和两个survivor spaces组成。最初,VM将所有的对象放入eden space,大多数对象死在那里~~~,当VM运行了一次minor GC,VM将剩余的对象从eden space移动到某个survivor space中。然后VM将那些在survivor spaces中生存了足够长时间的对象移动到位于old generation中的tenured spaces。当tenured spaces满了以后,将发生一次full GC,full GC涉及到所有存活的对象,因此比较慢。Permanent generation保存了所有的虚拟机自身的反射数据,比如class和method objects
默认情况下代的排列类于下图:
如同下文链接中说明的,如果垃圾收集器成为瓶颈,你可以通过自定义代大小来提高性能。使用jconsole可以发现你的性能情况对垃圾收集器参数的敏感程度。详细情况见:
监视线程使用:
线程选项卡提供了关于线程使用的信息。

左下角列出的为所有的活动线程。如果你在过滤(filter)对话框输入字符串,那么线程列表将尽显示那些包含你输入字符串的线程。程列表上点击线程名,可以显示在右侧显示县城信息,包括线程名,状态和调用堆栈。
图表显示了活动线程/时间。有三行内容:
Magenta:线程总数
Red:峰线程数
Blue:活动线程数。
关于线程、daemon线程详细信息,请查看链接:
监视Class加载:
Classes选项卡显示了关于class loading的信息:

图表显示了 类加载/时间
红线是类加载总数(包括后来卸载的)
蓝线表示当前的类加载数量。
选项卡底部的Detail节显示了自JVM启动后类加载的总量,当前加载量和卸载量。
监视和管理MBeans:
MBean选项卡显示了所有在platform MBean server上注册的MBeans的信息。

左边的树形结构显示了所有的MBean,按其对象名排序。当在树种选择了一个MBean之后,其属性、操作、通知和其他信息会在右边显示。
如果属性是可写的(可写会蓝色显示),你可以设置属性。你也可以调用在操作选项卡中显示的操作。
显示图表:
你可以通过双击属性的方法显示一个属性/时间图表,比如,如果你双击java.lang.GarbageCollector.Copy Mbean的CollectionTime属性,你会得到如下图所示的显示:
查看VM信息。
VM选项卡提供了JVM的信息。

这些信息包括:
Uptime:JVM启动后的总时间。
Processes CPU Time:JVM启动后消耗的总CPU时间。
Total Compile Time:即时编译(JIT compilation)消耗的总时间。JVM的具体实现决定JIT编译何时发生。Hotspot VM使用adaptive compilation,在这种方式zhogn ,VM使用标准的解释器(interpreter)运行一个应用程序,但是会分析其代码判断性能瓶颈或者”hot spots”。
本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-fly.com/a/jisuanjixue/article-44302-8.html
恐怖组织最后杀的是还是老百姓世界各地的百姓是无辜的