【问题标题】:OQL query to find all instances and sub-instances of a given class referred to from a sessionOQL 查询以查找会话中引用的给定类的所有实例和子实例
【发布时间】:2011-02-11 04:10:07
【问题描述】:

我正在尝试使用 jhat/OQL 来跟踪 Tomcat 容器中的内存泄漏。我想问的问题是:

“显示所有可以从 javax.servlet.http.HttpSession 访问的 foo.bar.Cacheable 类的实例(和子实例)”

我设法想出了以下内容,但这并没有显示 foo.bar.Cacheable 的子类(这很重要,因为这实际上是一个接口)。

select filter(reachables(s), "/foo.bar.Cacheable/(classof(it).name)") from javax.servlet.http.HttpSession s

我尝试了以下概念的各种排列,但不断收到错误(“foo”未定义)。

select filter(reachables(s), classof(it) instanceof foo.bar.Cacheable) from javax.servlet.http.HttpSession s

谁能帮我解决我在通过 OQL 提出这个问题时做错了什么?

【问题讨论】:

  • classof(it) 中的“它”是什么?
  • 'it' 是由 filter(..) 方法隐式提供的过滤器变量,表示要接受/拒绝的项目。

标签: java memory-leaks heap-memory oql jhat


【解决方案1】:

在基于 jhat 的 OQL 实现(jHat、VisualVM)中,您可以利用这样一个事实,即您不仅限于类似 SQL 的语法,而且您拥有一个完整的 JavaScript 引擎。

下面的代码可以解决问题

var containerSuperClass = "javax.servlet.http.HttpSession"
var elementSuperClass = "foo.bar.Cacheable"
// find the container class by name
var alClz = heap.findClass(elementSuperClass)
// retrieve all subclasses
var subClzs = alClz.subclasses()

// filter the list of objects reachables from instances of the container super class
// and all its subclasses so it contains only objects of classes from subClzs
map(heap.objects(containerSuperClass), 'filter(reachables(it), "it != null && contains(subClzs, containsClause(it))")')

// we need to externalize the contains clause because of clash in naming the closure parameter 'it'
function containsClause(rcbl) {
    return function(it) {
        if (rcbl == null || it == null) return false;
        return it.name.equals(classof(rcbl).name)
    }
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2020-09-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-02-05
    相关资源
    最近更新 更多