debug_debugging - CSDN
debug 订阅
DEBUG是计算机排除故障的意思。马克2号(Harvard Mark II)编制程序的格蕾丝·霍珀(Grace Hopper)是一位美国海军准将及计算机科学家,同时也是世界最早的一批程序设计师之一。有一天,她在调试设备时出现故障,拆开继电器后,发现有只飞蛾被夹扁在触点中间,从而“卡”住了机器的运行。于是,霍珀诙谐的把程序故障统称为“臭虫(BUG)”,把排除程序故障叫DEBUG,而这奇怪的“称呼”,竟成为后来计算机领域的专业行话。如DOS系统中的调试程序,程序名称就叫DEBUG。DEBUG在windows系统中也是极其重要的调试操作。 展开全文
DEBUG是计算机排除故障的意思。马克2号(Harvard Mark II)编制程序的格蕾丝·霍珀(Grace Hopper)是一位美国海军准将及计算机科学家,同时也是世界最早的一批程序设计师之一。有一天,她在调试设备时出现故障,拆开继电器后,发现有只飞蛾被夹扁在触点中间,从而“卡”住了机器的运行。于是,霍珀诙谐的把程序故障统称为“臭虫(BUG)”,把排除程序故障叫DEBUG,而这奇怪的“称呼”,竟成为后来计算机领域的专业行话。如DOS系统中的调试程序,程序名称就叫DEBUG。DEBUG在windows系统中也是极其重要的调试操作。
信息
中文名
消除故障
外文名
Debug
命名人
格蕾丝·霍珀
主要属性
操作程序
所属领域
计算机
DEBUG概念
1937年,美国青年霍华德·艾肯找到IBM公司为其投资200万美元研制计算机,第一台成品艾肯把它取名为:马克1号(mark1),又叫“自动序列受控计算机”,从这时起IBM公司由生产制表机,肉铺磅秤,咖啡研磨机等乱七八糟玩意儿行业,正式跨进“计算机”领地。为马克1号编制程序的是哈佛的一位女数学家格蕾丝·霍珀,有一天,她在调试程序时出现故障,拆开继电器后,发现有只飞蛾被夹扁在触点中间,从而“卡”住了机器的运行。于是,霍珀诙谐的把程序故障统称为“臭虫(BUG)”,把排除程序故障叫DEBUG,而这奇怪的“称呼”,后来成为计算机领域的专业行话。从而debug意为排除程序故障的意思。
收起全文
精华内容
参与话题
  • Debug

    千次阅读 2019-05-23 11:08:25
    Debug 】 1. 背景介绍 我们程序员一生与Bug纠缠不清,自然一辈子离不开调试 今天的话题就讲程序员与Debug不得不说的故事 百度上讲,调试是保证所提供的设备能够正常运行的必须程序,所有费...

    这里是修真院后端小课堂,每篇分享文从

    【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】

    八个方面深度解析后端知识/技能,本篇分享的是:

    【Debug 】

    1. 背景介绍

    我们程序员一生与Bug纠缠不清,自然一辈子离不开调试

    今天的话题就讲程序员与Debug不得不说的故事

    百度上讲,调试是保证所提供的设备能够正常运行的必须程序,所有费用由设备提供商负担。

    编好程序后,用各种手段进行查错和排错的过程。

    说道调试一定离不开Debug

    今天就重点讲讲Debug的故事

    DEBUG是一种计算机程序。

     

    马克2号(Harvard Mark II)编制程序的葛丽丝·霍波(Grace Hopper)是一位美国海军准将及计算机科学家,同时也是世界最早的一批程序设计师之一。 有一天,她在调试设备时出现故障,拆开继电器后,发现有只飞蛾被夹扁在触点中间,从而“卡”住了机器的运行。 于是,霍波诙谐的把程序故障统称为“臭虫(BUG)”,把排除程序故障叫DEBUG,而这奇怪的“称呼”,竟成为后来计算机领域的专业行话。

     

    2. Debugger

    Debugger是什么?干什么的?怎么用?

    我们经常使用到的“Debugger”只是用来帮助我们进行Debug的工具,“Debugger”本身不能自动完成“Debug”。

    我们可以回想一下我们是如何进行Debug的,在进行Debug的过程中,我们通过Debugger来完成以下工作:

    (1)监视“Debug对象”的状态;

    (2)控制“Debug对象”的运行;

    这些工作可以为“发现Debug对象中存在的问题”以及“对解决问题方案的检验”提供有用的信息。 监控工作有时只需要由软件就可以完成,有时不仅需要软件支持,还需要硬件的支持。 Debugger除了被用来Debug,还被用来帮助我们理解“Debug的对象”内部结构,因为我们用到的Debugger能够完成对“Debug对象”的监控工作, 在监控的过程中可以获取“Debug对象”动态特征的信息,这对我们理解其结构是非常有用的。

     

    先给一些快捷键

    F7:单步调试,会进入方法体,如果该方法体还有方法,则不会进入该内嵌的方法中

    F8:单步调试,不会进入

    F9:跳至下一断点

    Shift+F8:跳出

    Alt+F8:可以通过在 Debug 的状态下,选中对象,弹出可输入计算表达式调试框,查看该输入内容的调试结果 。

    暂时知道这么多就已经可以了

    怎么用,请移步视频区

    PPT:https://ptteng.github.io/PPT/PPT-java/java-task1-Debug.html#/

     

    Debug和程序员不得不说的故事_腾讯视频

     

    展开全文
  • IDEA中如何使用debug调试项目 一步一步详细教程

    万次阅读 多人点赞 2019-09-05 09:28:35
    在现在的开发中,我们经常采用Debug来追踪代码的运行流程,通常在程序运行过程中出现异常,启用Debug模式可以分析定位异常发生的位置,以及在运行过程中参数的变化。通常我们也可以启用Debug模式来跟踪代码的运行...

    原文链接:http://www.yxlzone.top/show_blog_details_by_id?id=2bf6fd4688e44a7eb560f8db233ef5f7

    在现在的开发中,我们经常采用Debug来追踪代码的运行流程,通常在程序运行过程中出现异常,启用Debug模式可以分析定位异常发生的位置,以及在运行过程中参数的变化。通常我们也可以启用Debug模式来跟踪代码的运行流程去学习三方框架的源码。

      所以学习下如何在Intellij IDEA中使用好Debug,主要包括如下内容:

        一、Debug开篇

        二、基本用法&快捷键

        三、变量查看

        四、计算表达式

        五、智能步入

        六、断点条件设置

        七、多线程调试

        八、回退断点

        九、中断Debug

        十、附:JRebel激活

     


    一、Debug开篇

      首先看下IDEA中Debug模式下的界面。

      如下是在IDEA中启动Debug模式,进入断点后的界面,我这里是Windows,可能和Mac的图标等会有些不一样。就简单说下图中标注的8个地方:

      ① 以Debug模式启动服务,左边的一个按钮则是以Run模式启动。在开发中,我一般会直接启动Debug模式,方便随时调试代码。

      ② 断点:在左边行号栏单击左键,或者快捷键Ctrl+F8 打上/取消断点,断点行的颜色可自己去设置。

      ③ Debug窗口:访问请求到达第一个断点后,会自动激活Debug窗口。如果没有自动激活,可以去设置里设置,如图1.2。

      ④ 调试按钮:一共有8个按钮,调试的主要功能就对应着这几个按钮,鼠标悬停在按钮上可以查看对应的快捷键。在菜单栏Run里可以找到同样的对应的功能,如图1.4。

      ⑤ 服务按钮:可以在这里关闭/启动服务,设置断点等。

      ⑥ 方法调用栈:这里显示了该线程调试所经过的所有方法,勾选右上角的[Show All Frames]按钮,就不会显示其它类库的方法了,否则这里会有一大堆的方法。

      ⑦ Variables:在变量区可以查看当前断点之前的当前方法内的变量。

      ⑧ Watches:查看变量,可以将Variables区中的变量拖到Watches中查看 

      [图1.1]

      

       [图1.2]:在设置里勾选Show debug window on breakpoint,则请求进入到断点后自动激活Debug窗口

      

      [图1.3]:如果你的IDEA底部没有显示工具栏或状态栏,可以在View里打开,显示出工具栏会方便我们使用。可以自己去尝试下这四个选项。

      

      [图1.4]:在菜单栏Run里有调试对应的功能,同时可以查看对应的快捷键。

      

     


    二、基本用法&快捷键

    Debug调试的功能主要对应着图一中4和5两组按钮:

      1、首先说第一组按钮,共8个按钮,从左到右依次如下:

         [图2.1]

        > Show Execution Point (Alt + F10):如果你的光标在其它行或其它页面,点击这个按钮可跳转到当前代码执行的行。

        > Step Over (F8):步过,一行一行地往下走,如果这一行上有方法不会进入方法。

        > Step Into (F7):步入,如果当前行有方法,可以进入方法内部,一般用于进入自定义方法内,不会进入官方类库的方法,如第25行的put方法。

        > Force Step Into (Alt + Shift + F7):强制步入,能进入任何方法,查看底层源码的时候可以用这个进入官方类库的方法。

        > Step Out (Shift + F8):步出,从步入的方法内退出到方法调用处,此时方法已执行完毕,只是还没有完成赋值。

        > Drop Frame (默认无):回退断点,后面章节详细说明。

        > Run to Cursor (Alt + F9):运行到光标处,你可以将光标定位到你需要查看的那一行,然后使用这个功能,代码会运行至光标行,而不需要打断点。

        > Evaluate Expression (Alt + F8):计算表达式,后面章节详细说明。

      2、第二组按钮,共7个按钮,从上到下依次如下:

          [图2.2]

        > Rerun 'xxxx':重新运行程序,会关闭服务后重新启动程序。

        > Update 'tech' application (Ctrl + F5):更新程序,一般在你的代码有改动后可执行这个功能。而这个功能对应的操作则是在服务配置里,如图2.3。

        > Resume Program (F9):恢复程序,比如,你在第20行和25行有两个断点,当前运行至第20行,按F9,则运行到下一个断点(即第25行),再按F9,则运行完整个流程,因为后面已经没有断点了。

        > Pause Program:暂停程序,启用Debug。目前没发现具体用法。

        > Stop 'xxx' (Ctrl + F2):连续按两下,关闭程序。有时候你会发现关闭服务再启动时,报端口被占用,这是因为没完全关闭服务的原因,你就需要查杀所有JVM进程了。

        > View Breakpoints (Ctrl + Shift + F8):查看所有断点,后面章节会涉及到。

        > Mute Breakpoints:哑的断点,选择这个后,所有断点变为灰色,断点失效,按F9则可以直接运行完程序。再次点击,断点变为红色,有效。如果只想使某一个断点失效,可以在断点上右键取消Enabled,如图2.4,则该行断点失效。

         [图2.3]:更新程序,On 'Update' actions,执行更新操作时所做的事情,一般选择'Update classes and resources',即更新类和资源文件。

           一般配合热部署插件会更好用,如JRebel,这样就不用每次更改代码后还要去重新启动服务。如何激活JRebel,在最后章节附上。

           下面的On frame deactivation,在IDEA窗口失去焦点时触发,即一般你从idea切换到浏览器的时候,idea会自动帮你做的事情,一般可以设置Do nothing,频繁切换会比较消耗资源的。

           

        [图2.4]

        

     


    三、变量查看

    在Debug过程中,跟踪查看变量的变化是非常必要的,这里就简单说下IDEA中可以查看变量的几个地方,相信大部分人都了解。

      1、如下,在IDEA中,参数所在行后面会显示当前变量的值。

       [图3.1]

      2、光标悬停到参数上,显示当前变量信息。点击打开详情如图3.3。我一般会使用这种方式,快捷方便。

       [图3.2]

       [图3.3]

      3、在Variables里查看,这里显示当前方法里的所有变量。

        [图3.4]

      4、在Watches里,点击New Watch,输入需要查看的变量。或者可以从Variables里拖到Watche里查看。

       [图3.5]

      如果你发现你没有Watches,可能在下图所在的地方。

       [图3.6]  

         [图3.7]

     


    四、计算表达式

      在前面提到的计算表达式如图4.1的按钮,Evaluate Expression (Alt + F8) 。可以使用这个操作在调试过程中计算某个表达式的值,而不用再去打印信息。

       [图4.1]

      1、按Alt + F8或按钮,或者,你可以选中某个表达式再Alt + F8,弹出计算表达式的窗口,如下,回车或点击Evaluate计算表达式的值。

         这个表达式不仅可以是一般变量或参数,也可以是方法,当你的一行代码中调用了几个方法时,就可以通过这种方式查看查看某个方法的返回值。

       [图4.2]

      2、设置变量,在计算表达式的框里,可以改变变量的值,这样有时候就能很方便我们去调试各种值的情况了不是。

       [图4.3]

     


    五、智能步入

      想想,一行代码里有好几个方法,怎么只选择某一个方法进入。之前提到过使用Step Into (Alt + F7) 或者 Force Step Into (Alt + Shift + F7)进入到方法内部,但这两个操作会根据方法调用顺序依次进入,这比较麻烦。

      那么智能步入就很方便了,智能步入,这个功能在Run里可以看到,Smart Step Into (Shift + F7),如图5.1

       [图5.1]

      按Shift + F7,会自动定位到当前断点行,并列出需要进入的方法,如图5.2,点击方法进入方法内部。

      如果只有一个方法,则直接进入,类似Force Step Into。

       [图5.2]

     


    六、断点条件设置

      通过设置断点条件,在满足条件时,才停在断点处,否则直接运行。

      通常,当我们在遍历一个比较大的集合或数组时,在循环内设置了一个断点,难道我们要一个一个去看变量的值?那肯定很累,说不定你还错过这个值得重新来一次。

      1、在断点上右键直接设置当前断点的条件,如图6.1,我设置exist为true时断点才生效。

        [图6.1]

      2、点击View Breakpoints (Ctrl + Shift + F8),查看所有断点。

        Java Line Breakpoints 显示了所有的断点,在右边勾选Condition,设置断点的条件。

        勾选Log message to console,则会将当前断点行输出到控制台,如图6.3

        勾选Evaluate and log,可以在执行这行代码是计算表达式的值,并将结果输出到控制台。

       [图6.2]

      

       [图6.3]

      

      3、再说说右边的Filters过滤,这些一般情况下不常用,简单说下意思。

        Instance filters:实例过滤,输入实例ID(如图6.5中的实例ID),但是我这里没有成功,不知道什么原因,知道的朋友留个言。

        Class filters:类过滤,根据类名过滤,同样没有成功....

        Pass count:用于循环中,如果断点在循环中,可以设置该值,循环多少次后停在断点处,之后的循环都会停在断点处。

      [图6.4]

       

       [图6.5]

      

      4、异常断点,通过设置异常断点,在程序中出现需要拦截的异常时,会自动定位到异常行。

      如图6.6,点击+号添加Java Exception Breakpoints,添加异常断点。然后输入需要断点的异常类,如图6.7,之后可以在Java Exception Breakpoints里看到添加的异常断点。

      我这里添加了一个NullPointerException异常断点,如图6.8,出现空指针异常后,自动定位在空指针异常行。

       [图6.6]

      

      [图6.7]

       

      [图6.8]

       

     


    七、多线程调试

      一般情况下我们调试的时候是在一个线程中的,一步一步往下走。但有时候你会发现在Debug的时候,想发起另外一个请求都无法进行了?

      那是因为IDEA在Debug时默认阻塞级别是ALL,会阻塞其它线程,只有在当前调试线程走完时才会走其它线程。可以在View Breakpoints里选择Thread,如图7.1,然后点击Make Default设置为默认选项。

      [图7.1]

       

      切换线程,在图7.2中Frames的下拉列表里,可以切换当前的线程,如下我这里有两个Debug的线程,切换另外一个则进入另一个Debug的线程。

      [图7.2]

       

     


    八、回退断点

      在调试的时候,想要重新走一下流程而不用再次发起一个请求?

      1、首先认识下这个方法调用栈,如图8.1,首先请求进入DemoController的insertDemo方法,然后调用insert方法,其它的invoke我们且先不管,最上面的方法是当前断点所在的方法。

      [图8.1]

       

      2、断点回退

      所谓的断点回退,其实就是回退到上一个方法调用的开始处,在IDEA里测试无法一行一行地回退或回到到上一个断点处,而是回到上一个方法。

      回退的方式有两种,一种是Drop Frame按钮(图8.2),按调用的方法逐步回退,包括三方类库的其它方法(取消Show All Frames按钮会显示三方类库的方法,如图8.3)。

      第二种方式,在调用栈方法上选择要回退的方法,右键选择Drop Frame(图8.4),回退到该方法的上一个方法调用处,此时再按F9(Resume Program),可以看到程序进入到该方法的断点处了。

      但有一点需要注意,断点回退只能重新走一下流程,之前的某些参数/数据的状态已经改变了的是无法回退到之前的状态的,如对象、集合、更新了数据库数据等等。

      图[8.2]

      

      图[8.3]

      

      图[8.4]

      

     


    九、中断Debug

      想要在Debug的时候,中断请求,不要再走剩余的流程了?

      有些时候,我们看到传入的参数有误后,不想走后面的流程了,怎么中断这次请求呢(后面的流程要删除数据库数据呢....),难道要关闭服务重新启动程序?嗯,我以前也是这么干的。

      确切的说,我也没发现可以直接中断请求的方式(除了关闭服务),但可以通过Force Return,即强制返回来避免后续的流程,如图9.1。

      点击Force Return,弹出Return Value的窗口,我这个方法的返回类型为Map,所以,我这里直接返回 results,来强制返回,从而不再进行后续的流程。或者你可以new HashMap<>()。

      [图9.1]

      

      [图9.2]

      

     


    十、附:JRebel激活

      目前本人一直使用JRebel做热部署工具,效果还算理想,修改Java代码或者xml等配置文件都能热更新。偶尔服务开久了,或更改的文件较多时,热更新没有生效,需要重新启动服务。

      这里只是简单说下我在网上看到的一种免费获得永久使用权的方式(非破解),不确定这种方式什么时候不能用。

      ① 首先你需要一个Facebook或Twitter的账号(最好Twitter)

      ② 进入这个网址:https://my.jrebel.com/,并登录,如图10.1

      ③ 然后在Install and Acticate里可以得到你的永久激活码。

      ④ 在设置里Jrebel里设置激活码,如图10.3,如果没有安装JRebel插件,先在Plugins里安装搜索安装JRebel插件。

      [图10.1]

       

      [图10.2]

      

      [图10.3]

      

    本文是作者转载用来备忘的!

    原文请看:http://www.yxlzone.top/show_blog_details_by_id?id=2bf6fd4688e44a7eb560f8db233ef5f7

     

     

    展开全文
  • debug 最全教程

    万次阅读 2018-07-27 10:04:08
    一、Debug视图 调试中最常用的窗口是: 窗口 说明 Debug窗口 主要显示当前线程方法调用栈, 以及代码行数(有调试信息的代码) 断点Breakpoints窗口 =&gt; 断点列表窗口,可以方便增加断点,设置断点条件...

    一、Debug视图


    调试中最常用的窗口是:


    窗口 说明
    Debug窗口 主要显示当前线程方法调用栈, 以及代码行数(有调试信息的代码)
    断点Breakpoints窗口 => 断点列表窗口,可以方便增加断点,设置断点条件,删除断点等
    变量Variables窗口 => 显示当前方法的本地变量,非static方法,包含this应用,可以修改变量值
    代码编辑窗口 => 这个不用多说了
    输出Console窗口 => 日志等输出内容,调试时,可以将关注的组件级别设置低一点,以便获得跟多输出信息


    另外辅助的窗口有:

    窗口 说明
    表达式expression窗口 => 写上自己需要观察的数据的表达式,或者修改变量值
    Display窗口 => 可以在display中执行代码块,输出内容等
    大纲Outline窗口 => 查看当前类的方法,变量等
    类型层级Type hierarchy窗口 => 查看当前所在类的继承层次,包括实现接口,类继承层次
    方法调用关系Call hierarchy窗口 => 查看当前方法被哪些方法调用,调用方法在哪些类中、第几行,可以直接打开对应的方法
    搜索结果Search窗口 => 结合快捷键可以查看变量、方法等在工作空间、项目、工作集中被引用或定义的代码位置

    1)窗口全览:





    2)Debug View(线程堆栈视图):


    debug视图允许您在工作台上管理正在调试和运行的程序,他显示了你正在调试的程序中挂起的线程的堆栈帧,程序中的每个线程作为树的节点出现。他展示了正在运行的每个目标的进程。如果线程被挂起,它的堆栈帧以子元素的形式展示。以下是一些常用的debug按钮:




    1.表示当前实现继续运行直到下一个断点,快捷键为F8。

    2.表示打断整个进程

    3.表示进入当前方法,快捷键为F5。

    4.表示运行下一行代码,快捷键为F6。

    5.表示退出当前方法,返回到调用层,快捷键为F7。

    6.表示当前线程的堆栈,从中可以看出在运行哪些代码,并且整个调用过程,以及代码行号


    详细介绍:


     Skip All Breakpoints : 将所有断点设置为被跳过的,设置了Skip All Breakpoints之后,所有断点上都会有一个斜线,表示断点将被跳过,线程不会在该断点处被挂起。


     Drop to Frame : 这个命令可以让程序回到当前方法的开头第一行重新开始执行,可以重新执行这个java堆栈帧,可以选择一个指定的堆栈帧,然后点击 Drop to Frame,这样就可以重新进入指定的堆栈帧。使用Drop to Frame时候需要注意:


    1.不能drop到已经执行过的方法栈中的方法中。

    2.drop到stack frame中时,不会改变全局数据原有的值,比如,一个包含元素的vertor并不会被清空。


     Step Filters : 这个功能比较简单,就是当我们在debug的时候想要忽略一些我们不关注的类时,可以开启Step Filters进行过滤,程序会一直执行直到遇到未经过滤的位置或断点。Step Filters功能由Use Step Filters,Edit Step Filters,Filter Type,Filter Package四项组成。具体操作如下:


    步骤 1: Windows -> Preferences -> Java -> Debug -> Step Filtering.



    步骤 2:选择‘Use Step Filters’

    步骤 3:在屏幕上选中所需的选项。你可以添加你自己代码库中的部分代码。

    步骤 4:点击‘Apply’


    原理上,Edit Step Filter命令用于配置Step Filter规则,而Filter Type与Filter Package分别指的是过滤的Java类型与Java Package。


     Step Return : 跳出当前方法,在被调用方法的执行过程中,使用Step Return会在执行完当前方法的全部代码后跳出该方法返回到调用该方法的方法中。


     Step Over : 在单步执行时,在函数内遇到子函数时不会进入子函数内单步执行,而是将子函数整个执行完在停止,也就是把子函数整个作为一步。


     Step Into:单步执行,遇到子函数就进入并且继续单步执行


     Resume:恢复暂停的线程,直接从当前位置跳到下一个断点位置。


     Suspend:暂停选定的线程,这个时候可以进行浏览或者修改代码,检查数据等。


    Eclipse通过Suspend与Resume来支持线程的暂挂与恢复。一般来讲,Suspend适用于多线程程序的调试,当需要查看某一个线程的堆栈帧及变量值时,我们可以通过Suspend命令将该线程暂挂。Resume用于恢复。


    有两种Resume需要注意:

    第一是当在调试过程中修改程序代码,然后保存,点击Resume,此时程序会暂挂于断点。

    第二是当程序抛出异常时,运行Resume,程序也会暂挂于断点。


     Terminate : Eclipse通过Terminate命令终止对本地程序的调试。


     Disconnect:Eclipse使用Disconnect命令来终止与远程JVM的socket连接。



    1、调试执行


    标记 功能 快捷键 描述
    6.4 Step Info F5 -> 单步进入(如果有方法调用,将进入调用方法中进行调试);
    6.4 Step Over F6 -> 单步跳过(不进入行的任何方法调用中,直接执行完当前代码行,并跳到下一行);
    6.4 Step Return F7 -> 单步返回(执行完当前方法,并从调用栈中弹出当前方法,返回当前方法被调用处);
    6.5 Resume F8 -> 恢复正常执行(直到遇到下一个断点);
    7.4 Run to Line Ctrl+R -> 执行到当前行(将忽略中间所有断点,执行到当前光标所在行);
    6.3 Drop To Frame -> 回退到指定方法开始处执行,这个功能相当赞
    在方法调用栈上的某个方法右键,选择Drop To Frame就可以从该方法的开始处执行
    比如重新执行本方法,可以在本方法上用Drop To Frame,将从本方法的第一行重新执行。
    当然对于有副作用的方法,比如数据库操作,更改传入参数的对象内容等操作可能重新执行就再是你想要的内容了。
    6.1+6.2 Copy Stack -> 拷贝当前线程栈信息

    如果在调试时,需要排除一些类、包等不需要进入调试,可以使用Edit Step Filters设置。 


    A6的properties: Java进程启动相关信息,包括控制台启动参数,环境参数等。如果参数启动参数有问题可以先看看这里的实际启动参数是不是有误。另外还可以查看虚拟机支持调试的相关选项。




    2、数据查看


    标记 功能 快捷键 描述
    7.4 Inspect ctrl+shift+i -> 察看选择的变量、表达式的值或执行结果, 再次按ctrl+shift+i可以将当前表达式或值添加到Expressions窗口中查看;
    7.4 Display ctrl+shift+d -> 显示选择的变量、表达式的值或执行结果, 再次按ctrl+shift+d可以将当前表达式或值添加到Display窗口中显示;
    7.4 Execute ctrl+u -> 执行选择表达式;
    7.4 Run to Line ctrl+r -> 执行到当前行(将忽略中间所有断点,执行到当前光标所在行);
    7.3 All Instances ctrl+shift+n -> 查看选择的类的所有对象,这个功能超赞;
    7.3 Instance Count -> 查看选择的类的所有对象个数;
    7.4 Watch -> 添加当前变量、表达式到Expressions窗口中;


    3)Variables View (变量视图)




    1.为变量名视图,显示当前代码行中所有可以访问的实例变量和局部变量

    2.显示所有的变量值

    3.可以通过该窗口来改变变量值


    Variables View显示与Debug View中选定的堆栈帧相关的变量信息,调试Java程序时,变量可以选择将更详细的信息显示在详细信息窗格中。此外,Java对象还可以显示出其包含的属性的值。在该窗口中选中变量鼠标右键点击可以进行许多操作,主要操作有以下这些:

    All Instances:打开一个对话框来显示该java类的所有实例,使用该功能需要java虚拟机支持实例的检索。

    All References::打开一个对话框来显示所有引用了该变量的java对象,

    Change Value::更改变量的值,该功能可以和Drop to Frame联合使用进行程序的调试。使用这两个功能就可以代替重新debug

    Copy Variables:复制变量的值,尤其在变量值很长(比如json数据)的时候,这个功能就派上用场了。

    Find:有的时候一个类中变量特别多的时候,可以进行查找。


    4)Breakpoints View (断点视图)




    1.显示所有断点

    2. 将当前窗口1中选中的端口失效,再次点击启用。

    3.异常断点


    Breakpoints View将列出你在当前工作区间里设置的所有断点,双击断点可以进入到程序中该断点的位置。还可以启用或禁用断点,删除,添加新的,根据工作组或点命中计数给他们分组。在使用断点是有以下两个技巧是十分有用的:

    Hit Count: 是指定断点处的代码段运行多少次,最典型的就是循环,如果要让一个循环执行10次就线程挂起,则指定Hit Count值为10,那么当前的循环执行到第九次的时候就会挂掉。

    Conditional:顾名思义,就是条件判断,例如我们需要循环变量i==10时,线程挂起,则条件设定为i==10,选择Suspend when “true”。


    那如果上面的Hit Count和Conditional都选择的话,如果表达式和值设置不合理则会失效。如果选择Suspend when value changes,那么可能在Conditional在变量值发生改变的时候就挂起。


    5)Expressions View (表达式视图)




    1.表达式

    2. 点击此可以新增一个表达式


    要在 Debug 透视图的编辑器中求表达式的值,选中设置有断点的一整行,并在上下文菜单中选择 Inspect 选项。表达式是在当前堆栈帧的上下文中求值的,其结果显示在 Display 窗口的 Expressions 视图中。 比如我想要计算变量a+b的值,那么就可以在表达式视图中加一个表达式:a+b


    6)Display View 




    可以使用这个视图,输入或者演算一些新的代码。这些代码在当前的调试位置的上下文环境中被执行,这意味着,你可以使用所有变量甚至是内容助手。要执行你的代码的话,只需标记它,并使用右键菜单或者CTRL+U(执行)或者 CTRL+SHIFT+I (检查)



    7)代码查看辅助窗口


    1、代码视图:


    代码视图,用来显示具体的代码。其中绿色部分是指当前将要执行的代码




    标记 功能 快捷键 描述
    11.1~11.5 quick type hierarchy ctrl+t 查看当前类、接口的继承层次, 默认进入时,显示继承/实现当前类/方法的子类,子接口11.1;再次ctrl+t,将显示当前类、接口继承/实现的超类/接口11.2;调试时,经常用该功能,在接口或抽象类的方法调用处11.3,ctrl+t察看实现类11.4,直接导航到对应的实现方法中11.5。
      quick outline ctrl+o 查看当前类的大纲,包括方法,属性等内容; 用处不大;
      open declarations F3 查看变量、属性、方法定义的地方



    2、Call Hierarchy窗口:


    标记 功能 快捷键 描述
    12.1~12.2 open call hierarchy ctrl+alt+h 查看方法被调用层次, 可以看当前方法被调用的地方12.1,或者当前方法调用了其他类的方法12.2



    3、Type Hierarchy窗口


    标记 功能 快捷键 描述
    13.1~13.4 open type hierarchy F4 查看继承层次, 可以查看类的继承层次,包括子类父类13.1, 或者类实现的接口继承层次13.2,还会根据选择的类/接口,在右边显示该类的大纲13.3、 13.4; 13.3可以选择是否显示父类/父接口的属性、方法等


    4、Search 窗口


    标记 功能 快捷键 描述
    14.1 declarations ctrl+g 相同的方法签名在工作空间中及第三方jar包中被定义的位置14.1
    14.2 references ctrl+shif+g 当前选中的变量、属性、方法在工作空间中及第三方jar包中被引用的位置14.2
    14.3   ctrl+shift+u 查看变量、属性 、方法在当前类中出现的地方14.3
    14.4 implements   查看实现当前接口的类14.8
    14.4~14.7 显示方式   可以选择不同的显示方式,具体看图




    二、Debug


    1.设置断点

    在源代码文件中,在想要设置断点的代码行的前面的标记行处,双击鼠标左键就可以设置断点,在相同位置再次双击即可取消断点。有的时候我们还有这样的需要,就是我并不想一行一行的执行代码,比如一个for循环会循环1000多遍,我只想在第500遍的时候让线程挂起进行调试,这个时候我们可以使用条件断点。 设置条件断点:我们可以给该断点设置触发条件,一旦满足某条件是才开始调试,可以在断点处点击鼠标右键,选择Breakpoint Properties进入断点设置页面,刚刚在讲断点视图的时候我们学到过Hit Count和Conditional的用法,这里可以设置条件和执行次数。


    1.1)断点类型及断点窗口

    在调试中可以设置的断点类型有五种:

     

    1.行断点(line breakpoints) : 条件断点,顾名思义就是一个有一定条件的断点,只有满足了用户设置的条件,代码才会在运行到断点处时停止。


    2.方法断点(method breakpoints ): 方法断点的特别之处在于它可以打在 JDK的源码里,由于 JDK 在编译时去掉了调试信息,所以普通断点是不能打到里面的,但是方法断点却可以,可以通过这种方法查看方法的调用栈。


    3.观察断点(watch breakpoints-成员变量访问变更)

    4.异常断点(exception breakpoints)

    5.类加载断点(class load breakpoints)


    每种断点的设置有些许不一样,可以在断点上右键->Breakpoint properties进行设置,但一般在断点窗口有快速设置的界面,Breakpoint properties中多了filter, 其实比较鸡肋,用处不大。


    断点相关的快捷键:


    快捷键 说明
    ctrl+shift+b 在光标处大断点/取消断点
    ctrl+alt+b 忽略所有断点
    Alt+shift+q, b 激活断点窗口

    1、行断点: 在方法中的某一行上打断点1.11.4。行断点可以设置挂起线程/VM的条件1.3,访问次数1.2。 
    1.3中的条件是,spring在注册Bean定义(registerBeanDefinition)时,如果是org.springframework.demo.MyBean,就挂起线程,可以开始单步调试了。 
    对于命中次数(hit count)1.2的使用,一般是在循环中,第N个对象的处理有问题,设置hit count = N, 重调试时,可以方便到达需要调试的循环次数时,停下来调试。


    2、方法断点:在方法上打断点2.12.2。方法断点的好处是可以从方法方法进入或者退出时2.3,停下来调试,类似行断点,而且只有行断点和方法断点有条件和访问次数的设置功能。 
    但是方法断点还有另外一个好处,如果代码编译时,指定不携带调试信息,行断点是不起作用的,只能打方法断点。 
    有兴趣的可以通过A1将Add line number… 前的勾去掉, 调试下看看。




    3、观察断点: 在成员变量上打的断点3.13.3。只有对象成员变量有效果,静态成员变量不起作用。 
    可以设置变量被访问或者设置的时候挂起线程/VM 3.2,也就是类似3.4的所有对成员变量的访问或者设置的方法都会被监控到 


    4、异常断点: 异常断点可以通过4.6添加,或者点击日志信息中输出的异常类信息添加。 
    异常断点4.1,系统发生异常时,在被捕获异常的抛出位置处或者程序未捕获的异常抛出处4.24.4, 挂起线程/VM, 也可以指定是否包括异常的子类也被检测4.34.5。 


    另外除了以上正常设置的异常挂起,从java->debug中可以设置挂起执行,主要有下面两个:

     

    1、是否在发生全局未捕获时挂起(suspend execution on uncaught exceptions),调试时,老是有异常挂起影响调试,但是没有设置异常断点的情况,就可以勾选掉这个选项;

    2、是否在编译错误时挂起,一般在边调试边改代码时会发生这种情况;


    另外要提一个的是有main方法启动的应用,可以在调试配置中勾选stop in main A3, 程序进入时,会挂起线程,等待调试。





    5、类加载断点: 在类名上打的断点5.1。接口上是打不了类加载断点的,但是抽象类是可以的,只是在调试的时候,断点不会明显进入classloader中,单步进入知会进入到子类的构造方法中,非抽象类在挂起线程后单步进入就会到classloader中(如果没有filter过滤掉的话)5.3。类加载断点不管是打在抽象或者非抽象类上,都会在类第一次加载或者第一个子类第一次被加载时,挂起线程/VM5.2





    2.调试程序


    1、调试本地 Java 语言程序


    在所有调试中,调试一个Java程序是最简单的,主要有设置断点、启动调试、单步执行、结束调试几步。

    1)设置断点:




    2)启动调试:Eclipse提供四种方式来启动程序(Launch)的调试,分别是通过菜单(Run –> Debug)、图标(“绿色臭虫”)、右键->Debug As以及快捷键(F11),在这一点上,与其他命令(例如Run)类似。




    弹出提示,需要切换到调试(Debug)工作区,勾选“Remember my decision”,记住选择,则下次不再提示,然后点击【Yes】。



    3)单步执行:主要使用前面讲过的几个视图进行调试,其中debug视图中的几个按钮有快捷键:

    Step Retuen(F7)

    Step Over (F6)

    Step Into (F5)





    结束调试:通过Terminate命令终止对本地程序的调试。


    二、案例


    场景一:小明写了一个任务执行者,该执行者不间断的执行一些任务,在现网上运行了一段时间后,发现有概率的出现一些故障,发现运行一段时间后,该任务者异常退出了,退出的因为是空指针,可以小明想要在本地debug,不知道断点打在哪里,该问题是概率事件,不一定会出现,所以小明debug几遍下来后,头晕眼花,连代码都看不清楚了,小明想要是能有个断点每当出现空指针异常的时候就停下来让他发现问题,那该多好呀。


    异常断点


    异常断点:在定位问题的过程中,常常会遇到断点无法打到合适的位置,以至于和问题的触发点千差万别,所以这个时候不妨试试异常断点,顾名思义,异常断点是指抛出某种异常后自动挂起的断点。

    点击红色部位,增加一个异常断点




    输入想要定位的异常类型,例如NullPointerException,这样系统中抛出任何NullPointerException异常后,都会挂起当前线程,给你机会去定位问题。


    场景二:小明写了一个巨大的循环,在调测代码时,小明发现每当循环到第100000次的时候,就是出现问题,没有达到自己的预期,于是小明在循环里打了个断点,想看看到底怎么回事,可小明万万没有想到,想要到达100000次循环是多么的困难,小明这个时候已经开始浮想联翩,如果能有这样的断点:

                 If 循环次数== 100000,线程停下来


    条件断点


    如右图,循环1000次,如果想要在循环到500次的时候停下来,可以创建一个条件断点,右击断点悬着Breakpoint Properties。




    选中Enable Condition

    在空白处,添加你自己的条件,如果条件返回true,线程会被挂起,如果为false,则忽略该异常

    Hit Count为该断点经过多少次后,正式挂起线程,如果设置为500,则表达前499次,经过该断点都不会停下,当第500次,该断点会挂起当前线程。




    表达式


    表达式可以查看一些在当前代码中没有的命令行,方便定位问题。


    场景三:小明最近遇到一个难题,在调用一个第三方插件时总是会有问题,小明怀疑是第三方插件的bug,但小明没有找到源码不能进行debug,小明该怎么办呢?


    Debug定位第三方插件的问题


    1.使用反编译工具将代码反编译

    2.将反编译后的源码进行过滤

    3.修复源码编译错误

    4.进行debug


    参考:

    http://blog.csdn.net/u010075335/article/details/51222493

                </div>
    
    展开全文
  • 学会使用debug模式调试代码

    千次阅读 2019-05-15 03:33:33
    学会通过debug模式调试代码是每一个开发的必修课。下面我通过一个案例来描述一下如何来调试、跟踪代码。 步骤:在接口或方法的入口打上调试端点,如下所示。 通过“debug as”运行代码,进入debug代码调试模式。 ...

    在企业开发中,质量和效率显得尤为重要。学会通过debug模式调试代码是每一个开发的必修课。下面我通过一个案例来描述一下如何来调试、跟踪代码。
    步骤:在接口或方法的入口打上调试端点,如下所示。
    在这里插入图片描述
    通过“debug as”运行代码,进入debug代码调试模式。
    下面介绍几个重要的调试技巧:step into(F5),进入函数内部调试、step over(F6),在当前函数步进调试、step return(跳出当前函数,返回调用该函数的函数内部调试)以及drop to frame(回到当前函数第一行代码的位置)。
    进入debug模式后,我们就可以通过F6进行步进调试了,当运行到stack.push(temp)方法时,
    在这里插入图片描述
    如果我们想看该方法内部的实现逻辑,那么我们就可以通过F5进入到该方法的内部,
    在这里插入图片描述
    同时,我们可以接着按F6在当前push函数中进行步进调试了。
    如果此时我们想跳出push函数,回到调用push函数的那层函数体的逻辑中,那么我们就可以按F7跳出当前函数:
    在这里插入图片描述
    如果我们本来想定位第n行函数内部的逻辑,结果因操作过快,鼠标的光标跳到了第n+1行,但是我们又不想重新启动debug程序,那么我们就可以通过drop to frame回到当前函数的第一行开始重新定位,需要注意的是,如果我们通过F5进入了函数fun(),那么此时我们按drop to frame时,会跳到fun()函数的第一行!
    F7的另一个作用:遇到不想调试的步数很多的循环不想一步一步的按F6调试时,我们可以在该循环下一行再打一个断点,然后按F7,光标就会越过该循环体直接定位在断点的位置:
    在这里插入图片描述
    在循环下一行打一个断点,按F7,直接越过循环体,跳到断点调试处:
    在这里插入图片描述

    技巧:debug状态查看执行的结果,当光标移到第n+1行时,可以通过ctrl+shift+D查看第n+1行之前的代码执行结果。
    在这里插入图片描述
    也可以右机鼠标通过“watch”来查看或者通过“inspect”来查看。

    展开全文
  • debug调试方法

    万次阅读 2018-08-07 10:20:10
    debug使用方法 2016年12月26日 08:50:25 阅读数:524 1.进入debug模式(基础知识列表) 1、设置断点  2、启动servers端的debug模式  3、运行程序,在后台遇到断点时,进入debug调试状态  ====================...
  • DEBUG各命令详细说明(很详细)

    万次阅读 多人点赞 2016-09-23 15:11:58
    DEBUG各命令详细说明 启动DEBUG 1.打开Windows命令窗口 在Windows 95/98的环境中,打开命令窗口的步骤为:点击“开始”→“运行”,输入“command”命令; 在WindowsXP及WIN7的环境中,打开命令窗口的步骤为...
  • 本博文系列参考自>第三版,作者:王爽 Dubug是dos,windows下提供的调试工具,使用该工具,可以查看和修改寄存器,内存的内容。同时可以在机器码级别跟踪程序源码的运行。 1.常用的debug功能 ...(4)用Debug
  • Eclipse中的debug模式使用指南

    万次阅读 多人点赞 2019-05-24 13:10:12
    Eclipse中的debug模式使用指 Debug模式是在eclipse的使用中非常常见的对程序进行debug的方式,通过debug模式我们可以更加方便快捷的定位问题出现的位置,并且找到原因进行修改.但是很多小白同学对debug模式的使用方式...
  • Eclipse的Debug调试技巧大全

    万次阅读 多人点赞 2017-02-12 13:49:30
    一、Debug视图 调试中最常用的窗口是: 窗口 说明 Debug窗口 主要显示当前线程方法调用栈, 以及代码行数(有调试信息的代码) 断点Breakpoints窗口 => 断点列表窗口,可以方便增加断点,设置断点...
  • java debug调试怎么用?

    万次阅读 多人点赞 2020-09-24 16:02:43
    在做项目的时候,尤其是涉及多个页面的传值的时候,debug调试十分有用,可以迅速帮你找到错误的原因! 用debug的好处: 1.跟踪变量,可以查看变量的值的变化 2.迅速找到错误的原因,节省时间,找错小帮手 那么...
  • 如何正确使用debug

    万次阅读 2017-10-25 15:46:38
    今天由长沙黑马程序员的老师给大家讲解一下如何正确的使用debug: 一、Debug课程引言 我们在写程序的时候,会经常出现一些问题也叫bug(如程序运行报错,结果与预期不符等),面对这些问题,特别是对于初学者而...
  • DEBUG各命令详细说明

    万次阅读 2018-03-21 12:26:46
    启动DEBUG1.打开Windows命令窗口在Windows 95/98的环境中,打开命令窗口的步骤为:点击“开始”→“运行”,输入“command”命令; 在WindowsXP及WIN7的环境中,打开命令窗口的步骤为:点击“开始”→“运行”,输入...
  • 1.更改pro文件: CONFIG+=debug_and_release CONFIG(debug, debug|release){ TARGET = tekapp_debug } else { TARGET = tekapp_release } make 或make debug -------生成debug版 make release
  • Nginx 开启 debug 日志的办法

    万次阅读 2013-09-12 17:30:05
    但有时有些难以挖掘的 bug,需要看到更详细的 debug 级别的日志,这时候,单单把 error_log 级别设置成 debug 是不行的,Nginx 记录下来的还是 info 级别以上的信息。你需要激活 Nginx 的 debug 日志才可以得到 ...
  • 显示 Debug 工具窗口:重置布局:重置默认布局:
  • idea中debug工具栏消失后如何显示

    万次阅读 2017-12-21 11:50:09
    idea中debug工具栏消失后如何显示
  • 如何使用log.debug()

    万次阅读 2019-12-16 21:47:36
    log4j是一个开源的日志,共分为六个等级:LOG、DEBUG、INFO、WARN、ERROR、和FATAL。 DEBUG是其中的一种日志级别。一般我们用这个方法的时候都是这样的: if(log.isDebugEnabled()){ log.debug("debug!"); } ...
  • Oracle中给用户赋予debug权限

    万次阅读 2015-02-09 15:16:42
    通过可视化工具(如PL/SQL Developer、Oracle SQL Developer)调试Oracle的存储过程时,如果遇到如下错误信息: ...ORA-06512: at "SYS.DBMS_DEBUG_JDWP", line 68 ORA-06512: at line 1 This session req
  • maven开启debug模式

    万次阅读 2017-12-31 20:13:13
    maven开启debug模式 Once the Maven debug level logging is enabled, it will print all the actions that it takes during the build process 其实只要在maven命令后加一个X就行,即maven clean install -X,...
  • eclipse如何远程debug/断开远程debug

    万次阅读 2018-12-26 10:02:02
    eclipse如何远程debug? 当你的代码已经部署到生产或者测试环境的时候,你如何debug判断线上的问题呢? debug之前必须保证本地代码和远程代码完全一致,否则将不能建立连接 在eclipse里,选中项目,右键-&gt;...
1 2 3 4 5 ... 20
收藏数 1,264,998
精华内容 505,999
关键字:

debug