java监视变量_Eclipse调试JDK源代码~watch(监视)变量时报:

在调试JDK源代码时遇到无法监视变量的问题,原因是编译时未生成LocalVariableTable。解决方案是重新编译源代码,添加-g选项以包含调试信息。通过替换rt.jar中相应类文件或调整Eclipse的类加载顺序,可以成功监视变量并避免错误。
摘要由CSDN通过智能技术生成

[背景:下载了JDK1.7,其中包含对应的源代码src.zip假设我要查看public Document parse(InputStream is){}函数的源代码。该函数在JDK的rt.jar的包javax.xml.parsers下]

本文相关内容:参照http://414149609.iteye.com/blog/1849185。点击打开链接

========================================================================================================

前因:

在测试文章String中null变为"null"字符串的问题 (点击打开链接)时需要调试进入String的valueOf(Object obj)方法,当时自己想查看传进来的obj是什么值。但在Variables窗口没有该变量,watch这个变量又显示””

调查:

是因为编译时,没有生成Localvariable table。我们使用的库*.class文件,缺省情况下,只生成行号和源文件信息。 LocalVariableTable在javac的实现里默认是不生成到Class文件里的吧。默认生成的调试符号信息只有LineNumberTable而已。

解决:

如何在编译时带上Localvariable table属性,如我这里想要编译生成String.class时能把LocalVariableTable也生成出来。

可以到我们本机的JDK安装目录下找到src.zip,打开找到其中的String.java。把它拷出来放到自己的一个目录中对它进行重新编译。命令如下:

javac -g String.java

然后我们将编译生成的三个文件String$1.java,String$CaseInsensitiveComparator.class,String.class(主要是这个文件)替换掉我们工程中引入的rt.jar包中的String.class。本人在操作时是把这三个文件都替换了。不知道如果只替换一个文件行不行(未测)。

至于如何替换参照http://414149609.iteye.com/blog/1849185。点击打开链接文章中所说。

第一种:放回它原来的地方,比如rt.jar的就放回rt.jar。这样会改变JDK,记得事先备份,做完了替换回来。(本人实测采用的是这种方法,可行,具体见相关说明)

第二种:-Xbootclasspath/p:***,这样让新的类在bootstrapclassloader里优先加载,/p表示在加载JRE之前。(不知是何意,可能是cmd命令之类的吧

1764de2150b076c721f288c216c8e31a.gif)

第二种:eclipse:Run Configuration -> Classpath -> Bootstrap Entries -> add your new class -> move to top (可以对你新添加的类attach相应的源码,这样debug时才对得上) 。(但是目录得按照class的包名来放,比如java/util/concurrent/ConcurrentLinkedQueue.class。源码也放在一起,方便eclipse源码匹配。不知是何意,等待原文作者的回答。)

相关说明

附:对于第一种方式,最初的时候自己一在纠结,如果把rt.jar包中的相关文件替换掉,[eclipse默认是无法调试JDK源代码的,即使添加了src.zip 作为source code也不能解析stack上的变量,只能看到类成员变量。原因很简单,JDK的源代码是使用 javac -g:none 参

(尝试1):先把rt.jar包解压出来,然后把文件替换掉,最后对替换后的进行压缩操作。这样操作有个问题,

原始的rt.jar包的目录结构是

84eb1c5a8a067750c4b7dea1e88fcf3c.png

而我自己替换后压缩的rt.jar目录结构是:

c4c94ba7dfde3c253b783811ad817030.png

7e16522c784fabd00912120abc605e02.png

多了一个rt文件夹。

不知道这是什么原理,如果哪位大神知道的话,望能留言指导下,万分感谢。

(尝试2):以winrar软件打开rt.jar时找到java文件夹下的lang文件夹下的String.class等文件

5b92b44b89c4d0f4e62e5c85b5339fd8.png

直接右键将其删除,再点击左上角的”添加“,把自己java -g String.java编译生成的文件加入进去。

刷新Eclipse中工程,再运行

此时在Variables窗口中就可以看到obj变量了。

171a5467eed628ebe9ba95437a5ac948.png

watch变量时也可以看到其值了,不会再报:错误了。

432b852edcfd0af920274991603947ab.png

至此问题解决。[1,你把鼠标放在一个jkd的类上按下F3,如果这时迁移到一个class文件拿去的话 2,class文件画面会有一个“关联源代码”按钮,点击这个按钮,然后从系统文件选择jdk下的src.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值