gpt4 book ai didi

java - 有没有办法在mat中使用OQL获取无法访问的对象?

转载 作者:行者123 更新时间:2023-12-02 19:28:13 29 4
gpt4 key购买 nike

我可以查询 com.google.common.cache.LocalCache$StrongAccessWriteEntry 的所有实例
在 mat 中使用 OQL:

SELECT * FROM com.google.common.cache.LocalCache$StrongAccessWriteEntry

我已在 mat 中启用保留无法访问的对象。因此结果包含可到达和不可到达的对象。现在我想获取所有无法访问的 com.google.common.cache.LocalCache$StrongAccessWriteEntry 实例(也称为无 gc 根),如下所示:

SELECT * FROM com.google.common.cache.LocalCache$StrongAccessWriteEntry WHERE unreachable=true

我可以使用 OQL 来完成吗?

最佳答案

是的,查询例如:

SELECT * FROM com.google.common.cache.LocalCache$StrongAccessWriteEntry r where r in (SELECT AS RETAINED SET objects s FROM OBJECTS ${snapshot}.@GCRoots s WHERE ((SELECT t FROM OBJECTS ${snapshot}.getGCRootInfo(s) t WHERE (t.@type = 2048)) != null))

应该这样做。

说明:

找到GC根:

SELECT objects s FROM OBJECTS ${snapshot}.@GCRoots s

找到GC根,然后为每个GC根获取GC根信息的数组,然后查看每个GCRootInfo并找到类型,看看它是否为Type.UNREACHABLE(2048),然后选择一个GC根,其中GC根信息显示无法访问。这会找到无法访问的对象根。保留不可达对象仅将部分不可达对象标记为 GC 根 - 其余不可达对象由这些根保留。查询比方式更好。

SELECT OBJECTS s FROM OBJECTS ${snapshot}.@GCRoots s WHERE ((SELECT t FROM OBJECTS ${snapshot}.getGCRootInfo(s) t WHERE (t.@type = 2048)) != null)

通过查找不可达GC root保留的所有对象来查找所有不可达对象:

SELECT AS RETAINED SET OBJECTS s FROM OBJECTS ${snapshot}.@GCRoots s WHERE ((SELECT t FROM OBJECTS ${snapshot}.getGCRootInfo(s) t WHERE (t.@type = 2048)) != null)

查找所有 LocalCache$StrongAccessWriteEntry 对象

SELECT * FROM com.google.common.cache.LocalCache$StrongAccessWriteEntry r

查找所有位于不可访问对象集中的 LocalCache$StrongAccessWriteEntry 对象。

SELECT * FROM com.google.common.cache.LocalCache$StrongAccessWriteEntry r where r in (SELECT AS RETAINED SET OBJECTS s FROM OBJECTS ${snapshot}.@GCRoots s WHERE ((SELECT t FROM OBJECTS ${snapshot}.getGCRootInfo(s) t WHERE (t.@type = 2048)) != null))

Eclipse Memory Analyzer wiki 中提供了有关编写查询的更多信息。 .

关于java - 有没有办法在mat中使用OQL获取无法访问的对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62208144/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com