黑马程序员技术交流社区
标题:
【太原校区】解决Debug时无法观察JDK提供的API类中变量的值
[打印本页]
作者:
郝永亮
时间:
2018-3-23 09:59
标题:
【太原校区】解决Debug时无法观察JDK提供的API类中变量的值
本帖最后由 郝永亮 于 2018-3-23 11:08 编辑
一.问题阐述
首先我们要明白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中复制到你的工作目录中,这样做的目的可以让你减少在命令行中输入的文件名。
6..执行如下这条命令:
[plain] view plaincopyprint?01.dir /B /S /X jdk_src\*.java > filelist.txt
dir /B /S /X jdk_src\*.java > filelist.txt
创建一个叫做filelist.txt的文件,这个文件存放了所有你将要编译的类的名称。
7.执行如下的命令:[plain] view plaincopyprint?01.javac -J-Xms16m -J-Xmx1024m -sourcepath e:\jdk_src -cp e:\rt.jar -d e:\jdk_debug -g @filelist.txt >> log.txt 2>&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 plaincopyprint?01.jar cf0 rt_debug.jar *
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一下,如果可以查看局部变量了,那么恭喜你成功了。
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2