Дамп потока Java - отрицательные номера строк - PullRequest
0 голосов
/ 26 июня 2018

Я просто пытался понять некоторые заблокированные элементы из дампа потока:

"Thread-65" : 151 : RUNNABLE : cpu=36796875000 : cpuLoad= 0.29151857
BlockedCount:94117 BlockedTime:-1 LockName:null LockOwnerID:-1 LockOwnerName:null
WaitedCount:16 WaitedTime:-1 InNative:false IsSuspended:false   at java.util.zip.ZipFile.open(ZipFile.java:-2)
    at java.util.zip.ZipFile.(ZipFile.java:219)
    at java.util.zip.ZipFile.(ZipFile.java:149)
    at java.util.jar.JarFile.(JarFile.java:166)
    at java.util.jar.JarFile.(JarFile.java:130)
    at org.apache.tomcat.util.compat.JreCompat.jarFileNewInstance(JreCompat.java:188)
    at org.apache.tomcat.util.compat.JreCompat.jarFileNewInstance(JreCompat.java:173)
    at org.apache.catalina.webresources.AbstractArchiveResourceSet.openJarFile(AbstractArchiveResourceSet.java:316)
    at org.apache.catalina.webresources.AbstractSingleArchiveResourceSet.getArchiveEntry(AbstractSingleArchiveResourceSet.java:96)
    at org.apache.catalina.webresources.AbstractArchiveResourceSet.getResource(AbstractArchiveResourceSet.java:265)
    at org.apache.catalina.webresources.StandardRoot.getResourceInternal(StandardRoot.java:281)
    at org.apache.catalina.webresources.CachedResource.validateResource(CachedResource.java:97)
    at org.apache.catalina.webresources.Cache.getResource(Cache.java:69)
    at org.apache.catalina.webresources.StandardRoot.getResource(StandardRoot.java:216)
    at org.apache.catalina.webresources.StandardRoot.getClassLoaderResource(StandardRoot.java:225)
    at org.apache.catalina.loader.WebappClassLoaderBase.getResourceAsStream(WebappClassLoaderBase.java:1067)
    at java.lang.Class.getResourceAsStream(Class.java:2223)
    at bsh.BshClassManager.getResourceAsStream(null:-1)
    at bsh.classpath.ClassManagerImpl.getResourceAsStream(null:-1)
    at bsh.BshClassManager.loadSourceClass(null:-1)
    at bsh.classpath.ClassManagerImpl.classForName(null:-1)
    at bsh.NameSpace.classForName(null:-1)
    at bsh.NameSpace.getImportedClassImpl(null:-1)
    at bsh.NameSpace.getClassImpl(null:-1)
    at bsh.NameSpace.getClass(null:-1)
    at bsh.Name.consumeNextObjectField(null:-1)
    at bsh.Name.toObject(null:-1)
    at bsh.Name.toObject(null:-1)
    at bsh.NameSpace.get(null:-1)
    at bsh.Interpreter.get(null:-1)
    at bsh.Interpreter.getu(null:-1)
    at bsh.Interpreter.(null:-1)
    at bsh.Interpreter.(null:-1)
    at bsh.Interpreter.(null:-1)

Что я не получаю, так это отрицательный номер строки.Значит ли это, что источник не найден?

1 Ответ

0 голосов
/ 26 июня 2018

Это все классы бобов.Я предполагаю, что они делают это, чтобы избежать путаницы.

Я предполагаю, что они используют это как "Уловку", чтобы удалить эти строки в некоторых условиях (например, когда вы работаете в repl beanshell).

Вы можете использовать этот же трюк для удаления этих строк из вашего дампа.

Этот, возможно, связанный вопрос Как получить полный журнал сценариев оболочки bean в jmeter

Предложил добавить директиву debug () в beanshell, чтобы получить менее ограниченную трассировку стека - возможно, если бы вы сделали это, она бы заполнила эти строки стека bsh?

...