1、打开电脑“myeclipse”找到需要调试的代码;
2、在左边边缘处双击设置调试断点;
3、鼠标右键点击代码区域,选择【Debug As】,然后选择【Java Application】;
4、接着d出跳转窗口提示对话框,不用担心,点击下方【YES】;
5、进入Debug视图,F5是【step into】即进入本行代码中执行,F6是【step over】, 即执行本行代码,跳到下一行;
F6、5执行之后在右方可以看到执行点代码结果,以及相应点属性值,类型;
7、使用F7来跳到上一个断点,F8返回下一个断点依次点查询,执行完毕后点击上方停止按钮,一步一步的对代码进行分块调试,直到找出问题解决问题。
启动Debug,它是可用于测试和调试
MS-DOS
可执行文件的程序。
Debug
[[drive:][path]
filename
[parameters]]
参数
[drive:][path]
filename
指定要测试的可执行文件的位置和名称。
parameters
指定要测试的可执行文件所需要的任何命令行信息。
++
说明
使用
Debug
命令但不指定要测试的文件
如果使用没有位置和文件名的
Debug
命令,然后键入所有的
Debug
命令以响应
Debug
提示符,连字符
(-)。
Debug
命令
以下是
Debug
命令列表:
?
显示
Debug
命令列表。
a
汇编
8086/8087/8088
记忆码。
c
比较内存的两个部分。
d
显示部分内存的内容。
e
从指定地址开始,将数据输入到内存。
f
使用指定值填充一段内存。
g
运行在内存中的可执行文件。
h
执行十六进制运算。
i
显示来自特定端口的
1
字节值。
l
将文件或磁盘扇区内容加载到内存。
m
复制内存块中的内容
/n
为
l
或
w
命令指定文件,或者指定正在测试的文件的参数。
o
向输出端口发送
1
个字节的值。
p
执行循环、重复的字符串指令、软件中断或子例程。
q
停止
Debug
会话。
r
显示或改变一个或多个寄存器。
s
在部分内存中搜索一个或多个字节值的模式。
t
执行一条指令,然后显示所有寄存器的内容、所有标志的状态和
Debug
下一步要执行的指令的解码形式。
u
反汇编字节并显示相应的原语句。
w
将被测试文件写入磁盘。
xa
分配扩展内存。
xd
释放扩展内存。
xm
映射扩展内存页。
xs
显示扩展内存的状态。
分隔命令参数
所有
Debug
命令都接受参数,除了
q
命令之外。可以用逗号或空格分隔参数,但是只有在两个十六进制值之间才需要这些分隔符。因此,以下命令等价:
dcs:100
110
d
cs:100
110
d,cs:100,110
指定有效地址项
Debug
命令中的
address
参数指定内存位置。Address
是一个包含字母段记录的二位名称或一个四位字段地址加上一个偏移量。可以忽略段寄存器或段地址。a,g,l,t,u
和
w
命令的默认段是
CS。所有其他命令的默认段是
DS。所有数值均为十六进制格式。
有效地址如下:
CS:0100
04BA:0100
在段名和偏移量之间要有冒号。
指定有效范围项
Debug
命令中的
range
参数指定了内存的范围。可以为
range
选择两种格式:起始地址和结束地址,或者起始地址和长度范围(由
l
表示)。
例如,下面的两个语法都可以指定从
CS:100
开始的
16
字节范围:
cs:100
10f
cs:100
l
10
++
Debug
子命令
选择
Debug
命令以获得详细信息。
Debug:A(汇编)
Debug:C(比较)
Debug(转储)
Debug:E(键入)
Debug:F(填充)
Debug:G(转向)
Debug:H(十六进制)
Debug:I(输入)
Debug:L(加载)
Debug:M(移动)
Debug:N(名称)
Debug:O(输出)
Debug:P(执行)
Debug:Q(退出)
Debug:r(寄存器)
Debug:s(搜索)
Debug:T(跟踪)
Debug:U(反汇编)
Debug:W(写入)
Debug:XA(分配扩展内存)
Debug:XD(取消分配扩展内存)
Debug:XM(映射扩展内存页)
Debug:XS(显示扩展内存状态)
是为DOS提供的有力的侦错,跟踪程序运行,检查系统数据的工具程序,它是在字符界面下以单字符命令方式工作。要很好地使用它必须具备一定的汇编程序设计和硬件基本知识的能力,当然,它为汇编语言程序员提供了有效的调试手段,它的功能包括以下几个方面。�1. 直接输入、更改、跟踪、运行汇镅栽闯绦颍华
2. 观察 *** 作系统的内容;�
3. 查看ROM BIOS的内容;�
4. 观察更改RAM内部的设置值;�
5. 以扇区或文件的方式读写软盘数据。�
在DEBUG中地址用段地址与段内地址来表示,而段地址可以明确地指出来,也可以用一个段指示器(段寄存器)来代表,用段寄存器表示时,其段地址就是此寄存器的内含值:�
如:用段地址和段内地址表示FOFF:0100�
用段寄存器和段内地址表示CSF:0100←CS指向F000�
下面列出了常用命令用法。
-A 地址 从指定地址开始编写小汇编程序,按两个回车键结束编辑
-U 地址 从指定地址开始反汇编32字节的机器指令,缺省地址则从上一U命令继续
-D 始址 终址 以16进制/Asc字符对照方式显示指定内存范围的数据,每行显示10H个字节
-E 地址 值表 用给出的值表(空格分隔)替换指定地址开始的内存单元,例:-E 100 'v' 1F 'hello'
-N 文件名 为后续的L/W命令约定所 *** 作的文件名
-L 地址 将N命令所指定文件的内容读入到指定内存位置。另,逻辑卷扇区直接读:-L 地址 逻卷号 起始逻扇号 扇数
-W 地址 将BX-CX个字节的内存数据写入N命令指定的文件中。另,逻辑卷扇区直接写:-W 地址 逻卷号 起始逻扇号 扇数
-R 寄存器名 显示并允许修改指定寄存器的值
-G=始址 终址 执行指定内存中的机器指令程序
-T=地址 单步执行机器指令,缺省地址则从上一T命令继续。另,继续跟踪m条指令:-T m
读取c:卷的引导扇区,并保存到Boot.1文件中,并简单分析引导程序的前面几条指令:
-L 1000 2 0 1
-N boot.1
-R bx 输入0000
-R cx 输入0200
-W 1000
-U 1000
读取第一个硬盘上的主引导扇区,并保存到MB.1文件中,在屏幕上显示硬盘分区表数据:
-A 100
yyyy:0100 mov dx,0080
yyyy:01xx mov cx,0001
yyyy:01xx mov ax,yyyy
yyyy:01xx mov es,ax
yyyy:01xx mov bx,1000
yyyy:01xx mov ax,0201
yyyy:01xx int 13
yyyy:01zz nop
-G=yyyy:0100 01zz
-N mb.1
-R bx 输入0000
-R cx 输入0200
-W 1000
-D 11be 11ff
Debugger
"Debugger"这个词按它的英文字面意思来讲是这样一种“装置”(-er),这种装置可以“消除”(De-)“系统中的缺陷”(bug)。然而事实上,迄今为止我们经常使用到的"Debugger"只是用来帮助我们进行Debug的工具,"Debugger"本身不能自动完成"Debug"。我们可以回想一下我们是如何进行Debug的,在进行Debug的过程中,我们通过Debugger来完成以下工作:
(1)监视“Debug对象”的状态;
(2)控制“Debug对象”的运行;
这些工作可以为“发现Debug对象中存在的问题”以及“对解决问题方案的检验”提供有用的信息。
监控工作有时只需要由软件就可以完成,有时不仅需要软件支持,还需要硬件的支持。
Debugger除了被用来Debug,还被用来帮助我们理解“Debug的对象”内部结构,因为我们用到的Debugger能够完成对“Debug对象”的监控工作,在监控的过程中可以获取“Debug对象”动态特征的信息,这对我们理解其结构是非常有用的。 Debug-如何打开debug开关 debug是设备调试,排错中非常重要也非常有效的手段。需要对网络协议和Quidway产品相对熟悉的情况下使用。
过程:首先输入
[Router]info-centerenable
使用console配置口时,输入:
[Router]info-centerconsole
[Router]info-centerconsoledebug
使用远程telnet时,输入:
[Router]info-centermonitor
[Router]info-centermonitordebug
此处以调试链路层协议ppp数据包为例
[Router]debuggingppppacket
『注意』
1.特权模式下debug可以从displaydebug看出现在有哪些调试开关是打开的
2.调试开关打开,对路由器性能会有相应程度的影响,所以用后请及时关闭调试信息:
[Router]undodebugall,或者ctrl+d亦可
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)