JVM线程堆栈是一个给定时间的快照,它能向你提供所有被创建出来的Java线程的完整清单. 每一个被发现的Java线程都会给你如下信息:–线程的名称;经常被中间件厂商用来识别线程的标识,一般还会带上被分配的线程池名称以及状态(运行,阻塞等等.)–线程类型&优先级,例如:daemonprio=3**中间件程序一般以后台守护的形式创建他们的线程,这意味着这些线程是在后台运行的;它们会向它们的用户提供服务,例如:向你的JavaEE应用程序**–Java线程ID,例如:tid=0x000000011e52a800**这是通过java.lang.Thread.getId()获得的Java线程ID,它常常用自增长的长整形1..n**实现–原生线程ID,例如:nid=0x251c**,之所以关键是因为原生线程ID可以让你获得诸如从操作系统的角度来看那个线程在你的JVM中使用了大部分的CPU时间等这样的相关信息.**–Java线程状态和详细信息,例如:waitingformonitorentry[0xfffffffea5afb000]java.lang.Thread.State:BLOCKED(onobjectmonitor)**可以快速的了解到线程状态极其当前阻塞的可能原因**–Java线程栈跟踪;这是目前为止你能从线程堆栈中找到的最重要的数据.这也是你花费最多分析时间的地方,因为Java栈跟踪向提供了你将会在稍后的练习环节了解到的导致诸多类型的问题的根本原因,所需要的90%的信息。–Java堆内存分解;从HotSpotVM1.6版本开始,在线程堆栈的末尾处可以看到HotSpot的内存使用情况,比如说Java的堆内存(YoungGen,OldGen)&PermGen空间。这个信息对分析由于频繁GC而引起的问题时,是很有用的。你可以使用已知的线程数据或模式做一个快速的定位。?123456789HeapPSYoungGentotal466944K,used178734K[0xffffffff45c00000,0xffffffff70800000,0xffffffff70800000)edenspace233472K,76%used[0xffffffff45c00000,0xffffffff50ab7c50,0xffffffff54000000)fromspace233472K,0%used[0xffffffff62400000,0xffffffff62400000,0xffffffff70800000)tospace233472K,0%used[0xffffffff54000000,0xffffffff54000000,0xffffffff62400000)PSOldGentotal1400832K,used1400831K[0xfffffffef0400000,0xffffffff45c00000,0xffffffff45c00000)objectspace1400832K,99%used[0xfffffffef0400000,0xffffffff45bfffb8,0xffffffff45c00000)PSPermGentotal262144K,used248475K[0xfffffffed0400000,0xfffffffee0400000,0xfffffffef0400000)objectspace262144K,94%used[0xfffffffed0400000,0xfffffffedf6a6f08,0xfffffffee0400000)
java中的一些引用都是存放在栈中的,栈的速度快,但是容量比堆小。像对象或者一些成员变量等则是放在堆中的。堆栈之间,通过地址来进行联系。栈中包含对应的堆中对象的地址,通过地址索引去查找相应的堆中元素。
写的有些乱,请见谅。