gpt4 book ai didi

Javassist insertbefore 行号不正确

转载 作者:行者123 更新时间:2023-11-29 04:34:12 24 4
gpt4 key购买 nike

我正在使用 Javassist 将 logback 记录器注入(inject) jar。

在记录器的模式中,我记录行号以及其他细节,如时间、线程、文件等。

使用 ctMethod.insertAfter() 注入(inject)时,生成日志的行号是正确的。但是当使用ctMethod.insertbefore()注入(inject)时,行号记录为-1

为什么会这样?我该如何解决这个问题?

最佳答案

发生这种情况是因为 Javassist 本身并没有在其代码中添加任何行号信息。在 Java 字节码中,行号信息通过行首信息表示。由于 Javassist 不更改或添加此类信息,因此看起来好像 insertAfter 代码放在最后一行,而 insertBefore 代码没有可用信息。

给定一些方法 foo,Javassist 将添加如下伪代码示例中的代码:

void foo() {
// inserted before - in line number information
// start line number 1
// original code
// start line number 2
// original code
// inserted after - still on line number 2
}

由于偏移量现在位于 insertBefore 代码之后,后面的代码不暗示任何行号信息(由值 -1 表示)。由于 insertAfter 代码隐式放置在最后一个偏移量之后,因此它看起来就像放置在最后一行中一样。

您可以通过在 Javassist 添加代码 after the line number information using insertAt 的相应行添加代码来避免这种情况.或者,您可以使用 Byte Buddy 进行代码操作,您可以在其中使用 Advice 组件添加代码。 insertBefore 等同于 @OnMethodEnter 注解 takes a property prependLineNumber这确实做你想做的。默认设置为 true

关于Javassist insertbefore 行号不正确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42437932/

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