图解JVM - 24.使用OQL语言查询对象信息

MAT支持一种类似于SQL的查询语言OQL(Object Query Language)。OQL使用类SQL语法,可以在堆中进行对象的查找和筛选。

OQL(Object Query Language)是JVM内存分析工具(如MAT)提供的对象查询语言,它允许开发人员直接对堆内存中的对象进行查询和分析。相较于传统的对象遍历方式,OQL具有以下优势:

  1. 类SQL的声明式语法
  2. 支持复杂对象关系导航
  3. 内置丰富的查询函数
  4. 支持正则表达式匹配

1. SELECT子句

在MAT中,Select子句的格式与SQL基本一致,用于指定要显示的列。Select子句中可以使用"*",查看结果对象的引用实例(相当于outgoing references)。

sql 复制代码
SELECT * FROM java.util.Vector v

使用"OBJECTS"关键字,可以将返回结果集中的项以对象的形式显示。

sql 复制代码
SELECT objects v.elementData FROM java.util.Vector v

SELECT OBJECTS s.value FROM java.lang.String s

在Select子句中,使用"AS RETAINED SET"关键字可以得到所得对象的保留集。

sql 复制代码
SELECT AS RETAINED SET *FROM com.atguigu.mat.Student

"DISTINCT"关键字用于在结果集中去除重复对象。

sql 复制代码
SELECT DISTINCT OBJECTS classof(s) FROM java.lang.String s

2. FROM子句

From子句用于指定查询范围,它可以指定类名、正则表达式或者对象地址。

sql 复制代码
SELECT * FROM java.lang.String s

使用正则表达式,限定搜索范围,输出所有com.atguigu包下所有类的实例

sql 复制代码
SELECT * FROM "com\.atguigu\..*"

使用类的地址进行搜索。使用类的地址的好处是可以区分被不同ClassLoader加载的同一种类型。

sql 复制代码
select * from 0x37a0b4d

3. WHERE子句

Where子句用于指定OQL的查询条件。OQL查询将只返回满足Where子句指定条件的对象。Where子句的格式与传统SQL极为相似。

返回长度大于10的char数组。

sql 复制代码
SELECT *FROM Ichar[] s WHERE s.@length>10

返回包含"java"子字符串的所有字符串,使用"LIKE"操作符,"LIKE"操作符的操作参数为正则表达式。

sql 复制代码
SELECT * FROM java.lang.String s WHERE toString(s) LIKE ".*java.*"

返回所有value域不为null的字符串,使用"="操作符。

sql 复制代码
SELECT * FROM java.lang.String s where s.value!=null

返回数组长度大于15,并且深堆大于1000字节的所有Vector对象。

sql 复制代码
SELECT * FROM java.util.Vector v WHERE v.elementData.@length>15 AND v.@retainedHeapSize>1000

4. 内置对象与方法

OQL中可以访问堆内对象的属性,也可以访问堆内代理对象的属性。访问堆内对象的属性时,格式如下,其中alias为对象名称:

. \] . . 访问java.io.File对象的path属性,并进一步访问path的value属性: ```sql SELECT toString(f.path.value) FROM java.io.File f ``` 显示String对象的内容、objectid和objectAddress。 ```sql SELECT s.toString(),s.@objectId, s.@objectAddress FROM java.lang.String s ``` 显示java.util.Vector内部数组的长度。 ```sql SELECT v.elementData.@length FROM java.util.Vector v ``` 显示所有的java.util.Vector对象及其子类型 ```sql select * from INSTANCEOF java.util.Vector ```

相关推荐
程序员爱钓鱼2 小时前
Python编程实战 · 基础入门篇 | 元组(tuple)
后端·python·ipython
程序员爱钓鱼2 小时前
Python编程实战 · 基础入门篇 | 列表(list)
后端·python·ipython
青云交4 小时前
Java 大视界 -- 基于 Java 的大数据机器学习模型在图像识别中的迁移学习与模型优化
java·大数据·迁移学习·图像识别·模型优化·deeplearning4j·机器学习模型
2501_909800814 小时前
Java 集合框架之 Set 接口
java·set接口
断剑zou天涯4 小时前
【算法笔记】暴力递归尝试
java·笔记·算法
Nobody_Cares5 小时前
JWT令牌
java
沐浴露z5 小时前
Kafka入门:基础架构讲解,安装与使用
java·分布式·kafka
神秘的土鸡5 小时前
从数据仓库到数据中台再到数据飞轮:我的数据技术成长之路
java·服务器·aigc·数据库架构·1024程序员节
vir026 小时前
P1928 外星密码(dfs)
java·数据结构·算法·深度优先·1024程序员节
摇滚侠6 小时前
全面掌握PostgreSQL关系型数据库,备份和恢复,笔记46和笔记47
java·数据库·笔记·postgresql·1024程序员节