调试OpenJDK

knowyourmeme.com/photos/531557 THX为@mihn

knowyourmeme.com/photos/531557 THX为@mihn

有时调试Java代码还不够,我们需要逐步了解Java的本机部分。

我花了一些时间来实现JDK的正确状态,所以简短的描述可能对开始旅行的人很有用。

我将使用全新的OpenJDK 9!

首先,您必须通过输入以下内容获取主存储库:

hg clone http://hg.openjdk.java.net/jdk9/jdk9 openjdk9

然后在openjdk9目录中输入:

bash get_source.sh

这会将所有源下载到本地文件系统。

从理论上讲,编译openjdk没什么大不了的,但是如果您想使用它进行调试,则会有一些(hmmm ....)奇怪的行为。

当然,首先我们需要调用./configure为系统准备特定的makefile。 我们可以阅读文档 ,我们必须添加–enable-debug标志来准备fastdebug构建。 如果您的系统中没有安装适当的库或工具,那么是时候安装依赖项了(配置输出将明确指出所有不足)。 配置并调用make命令后,您可能会遇到以下问题:

warning _FORTIFY_SOURCE requires compiling with optimization (-O)
Generating buffer classes
Generating exceptions classes
cc1plus: all warnings being treated as errors

凉! 它仅在某些特定的Linux安装中发生(不幸的是包括Fedora 20!)。 为了解决这个问题,我们必须删除_FORTIFY_SOURCE标志。 在以下文件中只需注释(#)行,其中包含_FORTIFY_SOURCE:

  • 热点/make/linux/makefiles/gcc.make
  • common / autoconf / flags.m4

然后,您可以继续进行jdk项目,十几分钟后您应该会看到:

Finished building OpenJDK for target 'default'

现在是时候将项目导入IDE了。由于我们仍在等待来自JetBrains的C ++ IDE,因此我们必须使用NetBeans甚至是Eclipse。 完成设置调试命令所需的几个步骤后(例如,甚至对于java -version )。 开始调试,然后…收到SIGSEGV 。 让我们通过在用户主目录中创建.gdbinit文件来解决此问题, 文件包含以下几行:

handle SIGSEGV pass noprint nostop
handle SIGUSR1 pass noprint nostop
handle SIGUSR2 pass noprint nostop

再开始调试一次-现在更好了! 让我们继续添加断点。 开始调试,并且……不起作用……! 我通过添加扩展了.gdbinit

set logging on

再进行一次调试尝试,在gdb.txt中,我看到了这样的一行:

No source file named hotspot/src/share/vm/memory/genCollectedHeap.cpp

我非常确定–enable-debug将向gcc编译器添加-g标志,但是看来我错了。 我花了几个小时进行谷歌搜索,并尝试通过更改gdb配置,NetBeans配置等解决它。仍然没有效果。 幸运的是, Michal Warecki指出,在调试构建期间,OpenJDK可能会压缩所有debuginfo的信息,如果您要调试(由于某些其他目的,当然也准备了调试构建?)。 在复制makefile文件之后,我发现了很有前途的disable-zip-debug-info标志。 因此,让我们将其包含在我们的配置调用中。 也相信我很难用C ++调试优化的代码(您可以尝试,但是您会遇到奇怪的事情,例如调试器以错误的顺序步进行(例如,从第4行开始的方法,回到第2行,然后回到第5行和第3行) !)。因此,我们将选择slowdebug选项以避免代码优化,整个正确的configure命令是:

bash ./configure --with-debug-level=slowdebug --with-target-bits=64 --disable-zip-debug-info

现在我们可以调用:

make

并等待编译完成。 现在,您可以通过调用build / linux-x86_64-normal-server-slowdebug / jdk / bin目录中的./java -version来检查一切是否正常

您应该看到:

openjdk version "1.9.0-internal-debug"
OpenJDK Runtime Environment (build 1.9.0-internal-debug-kuba_2014_08_20_14_02-b00)
OpenJDK 64-Bit Server VM (build 1.9.0-internal-debug-kuba_2014_08_20_14_02-b00, mixed mode)

让我们尝试调试。 添加断点,开始调试,然后……终于变成绿色了! 玩得开心!

翻译自: https://www.javacodegeeks.com/2014/08/debugging-openjdk.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值