Debug JDK source 无法查看局部变量的问题解决方案

一.问题阐述

首先我们要明白JDK source为什么在debug的时候无法观察局部变量,因为在jdk中,sun对rt.jar中的类编译时,去除了调试信息,这样在eclipse中就不能看到局部变量的值。这样的话,如果在debug的时候查看局部变量,就必须自己编译相应的源码使之拥有调试信息。

要达到这个目的,

一是找网上人家已经编译好的版本,剩下的只能自己去编译。

下面我们对于自己编译提供一个方法,希望对大家有所帮助。

二.解决方案

  1.   选择或创建你的工作目录,比如我选择:E:\
  2.   在你的工作目录中,创建文件夹jdk_src,用于存放源码;创建文件夹jdk_debug,用于输出编译结果。
  3.   从你的机器装jdk的地方找到src.zip,在你得JDK_HOME可以找到,比如我的在C:\Program Files\Java\jdk1.7.0_09目录下。然后把src解压到jdk_src目录下。
  4.   解压完后,选择你需要编译的内容,删除剩下的。一般选择如下的几个文件夹就可以了:java  javax  org 这三个目录就可以了啊
  5. .从你得JDK_HOMME\jre\lib\rt.jar中复制到你的工作目录中,这样做的目的可以让你减少在命令行中输入的文件名。
  6. .执行如下这条命令:
    [plain]  view plain copy 在CODE上查看代码片 派生到我的代码片
    1. dir /B /S /X jdk_src\*.java > filelist.txt  
    创建一个叫做filelist.txt的文件,这个文件存放了所有你将要编译的类的名称。
  7. 执行如下的命令:
    [plain]  view plain copy 在CODE上查看代码片 派生到我的代码片
    1. javac -J-Xms16m -J-Xmx1024m -sourcepath e:\jdk_src -cp e:\rt.jar -d e:\jdk_debug -g @filelist.txt >> log.txt 2>&1  
    这条命令将要编译所有你指定的文件,并把编译结果输出到jdk_debug目录中,同时产生log.txt日记文件。这个日记文件记录着编译警告,但是没有错误。
  8. 进入到jdk_debug目录中,输入如下命令:
    [plain]  view plain copy 在CODE上查看代码片 派生到我的代码片
    1. jar cf0 rt_debug.jar *  
    这个命令可以生成我们需要的rt.jar带编译信息的jar包。
  9. 把这个生成的rt_debug.jar包复制到JDK_HOME\jre\lib\endorsed。如果没有endorsed目录,自己创建一下。
  10. 如果你是在eclipse中debug的。点击Window->Installed JRES,选择相应的JDK,点击Edit,r然后选择点击Add External jars,选择我们步骤9中目中的rt_debug.jar,就可以了。现在完成了所有的步骤了,赶快尝试debug一下,如果可以查看局部变量了,那么恭喜你成功了。
二,下边是一种比较笨方式:

用Eclipse Debug,当跟踪进jdk api里时(比如javax.swing包里的类),无法查看某些local filed的值。这是因为jdk里的代码在打包时删除了一些用于调试的信息,以减小安装包的体积。不过可以通过重新编译jdk源代码来恢复此功能。

1.在Eclipse里新建一个java工程,把jdk_home/src.zip解压缩,复制java,javax两个目录的源代码到新建工程的src目录下。

2.build整个工程。如果build报Access restriction错误,是因为源代码里调用了com.sun等包的内容。可设置eclipse忽略这些错误。修改如下:

Windows -> Preferences -> Java -> Compiler -> Errors/Warnings -> Deprecated and trstricted API -> Forbidden reference (access rules): -> change to warning

3.可能还有个别错误,直接删除报错的源文件。

4.将编译得到的.class文件替换java_home/jre/lib/rt.jar文件里的.class文件。(用winrar打开rt.jar,直接把生成的java,javax包拖进去或,把src.zip解压出来,把刚刚上边编译的.class文件,全部替换掉这个src.zip解压出来的文件,再把这里所有文件再打成jar文件,据体怎么打jar包,看下边!红色部分)。

重启eclipse。现在调试时,跟踪到jdk api里的代码时,可以查看到相关的variable的信息了。


使用
java jar命令
比如您的class包存放路径为 d:\com\demo (demo是个目录,下面含有子文件夹及class文件)
具体操作如下:
1、打开dos窗口,进入demo目录
cd d:\com\demo
2、执行 jar cvf demo.jar * 回车
3、在demo目录下面你会发现demo.jar
具体参数请看下面的解释:
用法:jar {ctxu}[vfm0Mi] [jar-文件] [manifest-文件] [-C 目录] 文件名 ...    
  选项:    
  -c 创建新的存档 
  -t 列出存档内容的列表 
  -x 展开存档中的命名的(或所有的〕文件 
  -u 更新已存在的存档 
  -v 生成详细输出到标准输出上 
  -f 指定存档文件名 
  -m 包含来自标明文件的标明信息 
  -0 只存储方式;未用zip压缩格式 
  -M 不产生所有项的清单(manifest〕文件 
  -i 为指定的jar文件产生索引信息 
  -C 改变到指定的目录,并且包含下列文件:   
  如果一个文件名是一个目录,它将被递归处理。  


备注,这是一篇转载的文章,但是我试过了,按照他的步骤是可以的!!!
另附:jdk1.8的rt_debug.jar:
点击打开链接


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值