MAT对OQL的支持
前置文章:发布即巅峰!万字长文:Java性能调优六大工具:MAT内存分析工具
MAT的OQL语法与VisualVM支持的OQL有很大的区别。因此,笔者分为单独的两节分别对这两种OQL语言进行阐述。与VisualVM的OQL不同,MAT的OQL在语法上更接近传统的SQL语句。
一,Select子句
在MAT中,Select子句的格式与SQL基本一致,用于指定要显示的列。Select子句中可以使用“*”查看结果对象的引用实例(相当于outgoingreferences)。例如:
以上查询的输出结果如图6.100所示,在输出结果中,结果集中的每条记录都可以展开查看各自的引用对象。
与VisualVM的OQL类似,在OQL中,可以直接访问对象的属性。
下例输出所有Vector对象的内部数组,输出结果如图6.101所示。
下例将显示String对象的长度及内部数组。
MAT还支持自定义列名,下例便使用ASColName的形式自定义表格列名,结果如图6.102所示。
在Select子句中,使用ASRETAINEDSET关键字可以得到指定对象的保留集。下例得到
javatuning.ch6.toolscheck.shallowretained.Line对象的保留集,其结果如图6.103所示(堆快照文件为6.7.2节“浅堆和深堆”中的示例)。
在Select子句中,使用OBJECTS关键字可以将返回结果集中的项以对象的形式显示,例如下例的输出结果如图6.104所示。与图6.101相比,返回的结果已经被解析成完整的对象,而非简单的对象描述信息。