Java调试器–权威的工具列表

Java调试是一个复杂的空间。 调试器的类型很多,并且有很多工具可供选择。 在此页面中,我们将介绍7种类型的调试器之间的区别,并查看每个类别中的主要工具,以帮助您为正确的工作选择正确的工具。 公爵

以下是我们涵盖的调试器类型:

  • CLI调试器
  • IDE调试器
  • 构建自己的调试器
  • 堆转储
  • 历史调试器
  • 动态追踪
  • 生产调试
  • 塔基皮

定义

使用广泛的定义,错误是实例,其中我们编写的代码与我们获得的输入不匹配。 这些的不同影响可以大致分为–

  1. 意外的流控制 ,导致异常或代码中我们不想到达的位置。 在这里,调试器通常用于检查代码和状态的相关性。
  2. 意外的堆分配 。 在这种情况下,我们要么分配太多对象,要么分配太大。 保留对这些内容的长期引用只会增加乐趣。 这就是堆分析器起作用的地方。
  3. 延迟流量控制 。 这很可能与我们将错误的输入传递给外部调用(即“ SELECT * FROM everything”)或卡在长循环或无限循环中有关。 这是性能分析器通常会出现的地方。

当然,工具和类别之间存在重叠,因为它们本质上都具有相同的目的-让我们看到我们所期望的状态,以便我们可以修复代码,并使其达到期望。

1.命令行调试器

jstack

主要工具 :主要参与者是jdb ,它是JDK附带的,与JVM等效,是gdb。 它具有命令行界面,可以连接到正在运行的JVM。 像gdb一样,它的功能也很强大,您可以使用功能完备的IDE调试器使用jdb进行几乎任何操作。 jdb有一个补充-jstack-它使您可以在给定时刻打印实时JVM的线程调用堆栈。 但是,这不会捕获变量或堆状态。

以下情况下使用 :jdb的最大优点是其可移植性。 您可以相当快地将其安装到服务器上,而不必远程连接调试器。 如果您正在处理服务器上的恶劣环境,并且有能力让JVM检查它,那么jdb是您最好的朋友。

缺点 :jdb和jstack的缺点是,与其他命令行工具一样,它们在日常使用中效率不高。 这将我们带入下一个类别。

2. IDE调试器

网豆

主要工具 :Eclipse和NetBeans是该类别中的两个工具。 两者都使用与jdb类似的技术来附加或启动新的JVM。 虽然不是很轻便,但您确实会遇到很多麻烦,这可以使调试更短,更有趣。

以下情况下使用 :假设您每天都不是Dexter( 神童 ,而不是连环杀手)。

缺点 :作为高端桌面应用程序,它们不是您要在生产计算机上运行的东西。 始终存在进行远程调试的可能性,但是在复杂的环境中,解决该问题的可能性很小。

3.构建自己的调试器

blog_MyDebugger2

到目前为止,我们已经描述的所有调试器都基于相同的JVM开放调试架构,最常见的是使用JDWP(Java调试器有线协议)与正在运行的JVM进行通信。 JSwat是在此框架之上构建的独立调试器的示例。 是否想学习如何构建自己的Java / Scala调试器? 请点击这里 。

以下情况下使用 :构建自定义JVM扩展,或者对JVM的工作方式非常感兴趣。

缺点 :这是一件很复杂的事情,尤其是当您不想影响目标JVM的状态时,这是一件非常复杂的事情,因此您需要一个非常令人信服的理由来说明为什么您不能使用经过考验的现有工具。

4.堆转储

虚拟机

主要工具 :jmap,MAT。 在很多情况下,就像Rick Grimes一样 ,您正在与死者打交道。 在这些情况下,您正在查看的是JVM堆的快照,而不是已停滞的实时JVM的快照。 JDK附带的jmap允许您从实时JVM生成堆转储。 有很多工具可以让您浏览和分析转储。 jhat和visualVM都是JDK附带的,在这方面做得很好。 Eclipse插件MAT和NetBean的HeapWalker是很好的选择,因为它们利用了已经强大的IDE UI。

以下情况下使用 :发生复杂错误且无法应用常规调试技术(例如,该应用程序在客户的服务器上运行)。 另一种选择是通过打开JVM -HeapDumpOnOutOfMemoryError标志来使用堆转储来分析内存泄漏,以使JVM在堆耗尽后自动转储堆的内容。

缺点 :使用堆转储的最大缺点是它们的重量与堆本身的重量一样大(这很可能意味着堆在GB中)。 然后必须将其转回给您进行分析。 在生产中捕获它们也不是在公园中漫步。

5.历史调试器

chornon1

主要工具 :这种工具类别取决于您是否能够或不想停止JVM来收集状态或进行堆快照。 Chronon DVR是这种方法的一个很好的例子。 在此,调试器使用字节码检测从代码本身内部记录数据。 这通常包括诸如调用方法的顺序以及传递给它们的参数之类的事情。 这使调试器可以“重播”代码,并让您了解执行时的流控制。 重播解决方案(由CA收购)是另一种使用不同方法的示例,其中记录了对JVM的IO输入,然后将其“重播”回活动实例–模拟执行后的代码。

以下情况使用 此类工具的主要途径通常是在质量检查期间,通过捕获实际的运行时状态,它们可以帮助使错误更易于重现。 另一种情况是让客户或支持工程师临时运行该工具,以在应用程序在生产中表现异常时从JVM捕获状态。

缺点 :这些工具的最大缺点是日志记录会花费您很多时间,而日志记录会花费很多。 这意味着历史悠久的调试器可以将应用程序的速度降低50%到一个数量级,从而限制了可以使用这些应用程序的生产方案的数量。

6.动态跟踪

btraceResults

主要工具 :BTrace。 使用此类别中的工具,您可以从正在运行的JVM中有选择地打印(“跟踪”)状态信息,而无需停止它,也不必记录正在发生的一切。 可以将它视为动态编织到一段新代码中,该新代码从代码本身中打印值以供您查看。 BTrace是一个杰出的工具,它引入了自己的语法,可让您定义在代码上的何处以及要追踪的内容。 该语法还设计为仅支持只读操作,以防止您实际更改程序的状态或引起无限循环。

以下情况下使用 :最常用于尝试针对特定问题(例如连接池已耗尽)调试服务器或在不停止JVM执行的情况下临时收集特定统计信息的情况。

缺点 :与调试器一样,通常不建议从生产服务器进行动态跟踪(并且很多时间是不允许的)。 还有一个小的学习曲线,可以在服务器环境中有效地使用动态跟踪。

7.生产调试

Logstash

主要工具 :用于记录状态的日志记录框架(log4j,Logback)和用于按比例分析数据的日志分析器(Logstash,Splunk…)。

以下情况下使用 :这是一个相当坚韧的区域,因为当您处理生产系统时,使JVM停顿以查看状态或进行堆转储通常是很大的禁忌。 那是因为您实际上是要关闭服务器来调试它,这通常仅在极端情况下才能完成。

我们通常在运行时从JVM中提取状态而不停止状态的方法是通过有选择地将变量值记录到文件中(通常是在Java记录框架的帮助下)。 稍后,我们可以使用各种工具来解析数据,从简单到尾部,一直到可扩展的日志分析器,例如开源Logstash和企业Splunk。

缺点 :这里最大的缺点是我们当然需要事先知道(并有效地进行记录)。 日志也可以很快被填满,而且开发团队无需太多纪律,也可能包含很多不必要的数据或错过了一些关键数据。

科学家观察到,将日志文件中的数据拼接在一起以了解导致错误的可变状态,这是夜间和假日消遣的一种非常受欢迎的开发人员。


塔基皮

我们在构建Takipi时考虑了一个简单的对象。 我们想让开发人员轻松知道何时以及为什么生产代码中断。 这意味着每当新的异常或日志错误开始发生时,我们都会捕获它并通知您。 第二部分是跟踪部署,以判断问题从哪个原因开始以及发生的频率。 最后(也是最有趣的部分)是生产调试部分。 对于每个异常或错误,Takipi会在错误发生时向您显示确切的源代码和变量状态(包括本地值和对象值),就像发生错误时您就在那里一样。

参考: Java Debugger –我们的JCG合作伙伴 Tal Weiss在Takipi博客上的权威 工具清单 。

翻译自: https://www.javacodegeeks.com/2013/12/java-debugger-the-definitive-list-of-tools.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/365426.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java项目中多个定时器_在java项目中如何使用Timer定时器

在java项目中如何使用Timer定时器发布时间:2020-11-16 16:36:16来源:亿速云阅读:97作者:Leah在java项目中如何使用Timer定时器?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大…

慎使用sql的enum字段类型

在sql的优化中,会有同学提到一点:使用enum字段类型,代替其他tinyint等类型。以前这也是不少人喜欢优化的,但是现在细想,是非常不合理的。 优点: 1.可以设置区间范围,比如设置性别:1男…

js对HTML字符转义与反转义

注意: 在编写html时,经常需要转义,才能正常显示在页面上。 并且,还可以防止xss。 解决方案: 一, 使用正则: 使用正则转码: var value document.getElementById(input).value.t…

python三维数据图_matplotlib中三维数据的热图

我想用我的三维数据生成一张热图。在我已经能够用这些数据绘制出trisurf。在有人能帮我制作热图吗?我看到了在线教程,但是它们对3D来说都很复杂,我在这个网站上找到了一个在matplotlib中生成带有散点的热图,但是它只有2D数据。在我…

区分基于Ant目标的Gradle任务

在我的博客文章《 从Ant Build演变Gradle构建:导入Ant构建文件》中 ,我演示了如何使用Gradle内置的基于AntBuilder的Ant支持在Gradle构建中导入Ant目标。 然后,可以将这些Ant目标作为Gradle任务进行访问,并与Gradle构建直接引入的…

java显示长度和第一个字符_从Java字符串中以长度1的字符串返回的第一个字母的最佳方法是什么?...

假设以下内容:String example "something";String firstLetter "";以下分配方式firstLetter可能会影响性能,请注意是否存在差异; 哪个最好,为什么?firstLetter String.valueOf(example.charAt(…

sequelize difference between hasone and hasmany

Query is equal, hasone return the first instance from the collection,hasmany return the whole collection. 转载于:https://www.cnblogs.com/ybleeho/p/9772902.html

localStorage封装借口store.js的使用

localstorage是 HTML5 提供的在客户端存储数据的新方法,主要作用是将数据保存在客户端中,并且数据是永久保存的,除非人为干预删除。localstorage 的局限 1、只有版本较高的浏览器中才支持 localstorage2、localStorage的值的类型限定为strin…

AmazonSQS和Spring用于消息传递队列

下一篇文章将演示如何将Spring JMS模板和DLMC与AmazonSQS API一起使用,以放置消息队列。 我为什么要使用Amazon SQS? 易于配置 跨平台支持 从您的自我冗余,连带和扩展方面的烦恼中赚钱。 为什么我不使用Amazon SQS? 如果延迟…

3.3-3.9 周记

3.3-3.10 1. NIM游戏 百度链接:https://baike.baidu.com/item/Nim%E6%B8%B8%E6%88%8F/6737105?fraladdin 定义: P局面:先手必败N局面:先手必胜P局面的所有子局面都是N局面。N局面的子局面中必有一个是P局面 性质:\(a_…

关于类的使用的几个关键

类的定义和声明必须放在main函数前 如果类中只有申明类而没有定义,则只能定义指针:Test *test;如果不定义类而仅仅声明类的话,当使用Test test时,编译器只知道Test是个class,但留多大空间?怎么初…

java判断对象已死_Java的JVM判断对象已死的基本算法分析

jvm中有各种的垃圾收集器,每个收集器都有各自的算法。但是一切的根本都需要找到找到应该被消除的对象,理解如何找到死亡对象才是理解垃圾收集器的基础。01两个基本算法a、引用记数法:对象中加一个引用计数器,每次被引用计数器加一…

Java开发中更多常见的危险信号

在《 Java开发中的常见危险信号》一文中,我研究了一些不一定本身就是错误或不正确的做法,但它们可能表明存在更大的问题。 这些“红色标记”类似于“代码气味”的概念,我在这篇文章中引用的某些特定“红色标记”被称为“代码气味”。 正如我在…

python平均分由高到低顺序排列输出选手编号和最后得分_python 字典的使用案例二:求平均分,并按平均分由高到低输出选手编号和最后得分...

校园好声音大赛,三位选手得分,由8位评委给出。请根据评分表,将每们选手的得分去掉一个最高分和一个最低分后求平均分,并按照平均分由高到低输出选手编号和最后得分。dicScores {012: [90, 94, 97, 86, 85, 89, 88, 85], 005: [91…

java开发 职业技能_java编程开发程序员需要具备哪些职业技能

随着互联网的不断发展,java编程开发可以说是目前学习人数和应用范围非常多的一种编程语言了,而今天我们就一起来了解一下,java编程开发程序员需要具备哪些职业技能。1、数据结构和算法分析数据结构和算法分析,对于一名程序员来说&…

Django model转字典的几种方法

平常的开发过程中不免遇到需要把model转成字典的需求,尤其是现在流行前后端分离架构,Json格式几乎成了前后端之间数据交换的标准,这种model转dict的需求就更多了,本文介绍几种日常使用的方法以供参考,所有例子均基于Dj…

微信小程序日历课表

最近项目中使用到了日历&#xff0c;在网上找了一些参考&#xff0c;自己改改,先看效果图 wxml <view class"date"><image class"direction" src"/images/icon/left.png" bindtapminusMouth/><label>{{year}}年{{mouth}}月<…

Java:将条件移至消息文件

Java类ResourceBundle和MessageFormat提供了一个很好的工具集&#xff0c;用于解决Java应用程序内部的本地化消息。 这篇文章提供了一个小示例&#xff0c;说明如何使用ChoiceFormat将与消息相关的简单条件从Java代码移动到消息文件中。 如果您已经知道ChoiceFormat我认为您不会…

【LuoguP3241】[HNOI2015] 开店

题目链接 题意 给出一棵边带权的树&#xff0c;多次在线询问一个点到一个区间内的点的距离和。 Sol 分块过不了的 一个 trick &#xff0c;都知道要算两点之间距离可以拆成到根的距离和他们的 LCA 到根的距离 &#xff0c;其实要算多个点到一个点距离也可以使用一个类似的 tric…

windows中的项目拷贝到linux中,部分数据不显示的原因

linux严格区分大小写&#xff0c;可能是数据表名大小写导致的。 如上传文件不成功&#xff0c;可能是系统权限导致的。转载于:https://www.cnblogs.com/miaoxingren/p/9784743.html