电脑玩剑灵卡怎么办问题~

西西软件下载最安全的下载网站、值得信赖的软件下载站!
→ Delphi在调试的时候查看变量的值
调试概述除非你的程序只有几行,否则几乎不可能一次写成,因此调试就非常必要。然而许多初学者不知道如何进行调试,写完程序就运行,发现结果不对再看代码,这样觉得非常吃力。这里,简单介绍一下所提供的调试功能。1. 语法检查(Syntax Check)Delphi提供了语法检查的功能,这个功能和正常编译很相似,同样也会给出各类错误和警告信息,但是不会生成代码。Delphi的编译信息分为4类:Fault(故障),Error(错误),Warning(警告)和Hint(提示)。Fault是指导致编译程序不能继续工作的错误,例如内存溢出等;Error是指发现用户程序不符合某些规定而导致不能按照用户程序的要求进行处理;Warning是指用户程序使用了某些不符合规定的形式,但是并不影响编译程序生成目标文件;Hint是指编译程序对用户程序的某些形式提出了怀疑。前两类信息是必须要解决的,否则你不能运行你的程序,但是往往会有很多人忽略后两种信息。然而,这些信息却是非常重要的。2. 启动、暂停、中止集成调试程序最基本、最重要的调试手段包括:单步跟踪、断点、变量观察、堆栈检查等。所有这些功能在Delphi的集成调试程序中都能提供。当你按下F9(Compile and Run,编译并运行)一个程序时,就已经启动了Delphi的集成调试程序,而按下Ctrl+Break(Program Pause,程序暂停)时则会暂停被调试程序返回到集成调试程序中去,再次按下F9会从暂停地地方继续执行,而Alt+F2(Program Reset,程序复位)则会完全中止被调试程序的执行,返回集成调试程序中去。3 单步跟踪(Step)所谓单步跟踪是指一行一行地执行程序,每执行一行语句后就停下来等待指示,这样你就能够仔细了解程序的执行顺序,以及当时的各种状况。注意:虽然Object Pascal允许在一行内书写任意多的语句,但是所有的单步跟踪都以“行”为单位,因此为了便于调试,主张在一行内只写一条语句,否则会给你带来很大的麻烦。单步跟踪可以分为Step Over(跳过)、Trace Into(跟踪进入)和Trace to Next Source Line(跟踪到下一条源代码行)。Step Over和Trace Into都是执行一行语句,差别在于遇到过程和函数时Trace Into将会进入过程和函数,而Step Over不会,而只会把过程和函数作为一条语句执行。当使用Ctrl+Break暂停程序时,程序不一定停在你的源代码位置上,而可能是在操作系统或者其它模块中,此时集成调试程序会出现一个CPU窗口(CPU Window),用汇编指令的形式显示当前的内容,可以用Trace to Next Source Line继续执行程序,直到程序执行到第一条有源代码的地方。4 断点(Breakpoint)断点是调试中非常重要的一个手段。由于在执行到某些代码前需要执行许多其它代码,不可能用单步跟踪一条一条执行过来,这时只要在需要暂停的地方设置一个断点,然后让程序运行,当执行到这个断点位置时不需要用户干预就会暂停并返回集成调试程序。Delphi提供了丰富的断点功能,包括:源代码断点、指令断点、数据断点等。源代码断点(Source Breakpoint)是指在你的源程序中设置断点,指令断点(Address Breakpoint)是指在某机器指令处设置断点,数据断点(Data Breakpoint)是指当写入某变量时暂停用户程序。所有的断点都可以设置更详细的属性,包括:条件、通过次数、组、高级操作等。条件(Condition)是指触发断点的条件,例如你可以写:a=10,表示当a等于10时在这个断点位置暂停;通过次数(Pass Count)是指即使符合条件,也需要执行这些次数才N暂停,例如在某断点设置通过次数为5,则表示当第5次通过这个断点时才暂停程序,当然,如果有条件存在的话还要符合相当次数的条件;组(Group)是指一组断点,你可以用一个名字来标记许多断点,这样你可以用禁止或允许组(Disable Group/Enable Group)来同时打开或禁止多个断点。高级操作是指和每个断点相关的一些行为(Action),具体如下:中断(Break):中断程序,这是默认操作。 忽略后续异常(Ignore subsequent exceptions):通过这个断点后忽略所有异常(exceptions); 处理后续异常(Handle subsequent exceptions):通过这个断点后处理异常,这和前一个操作是对应的; 记录信息(Log message),通过这个断点时记录一条事件日志信息,你可以在事件日志(Event Log)中查看这条信息; 表达式求值(Eval expression):对指定的一个表达式进行求值,并且可以通过记录结果(Log result)把这个结果记录在日志中; 禁止/允许组(Enable group/Disable group):通过这个断点以后禁止或者允许其它的组,由此可以控制其它断点的状态。 在Delphi中除了上述的显式断点以外,还提供了隐式断点:运行到光标(Run to cursor)和运行到返回(Run until return)。运行到光标是让程序到当前光标所在程序行,相当于你在当前光标位置设置了一个断点。这是一次性断点,并且如果在到达这里前遇到了其它断点,会停止在那个断点的地方,同时取消了这个临时断点。运行到返回是用于过程和函数中,运行到过程和函数退出的位置,使得可以迅速返回上层调用程序。5. 变量查看(Watch)/检查(Inspect)在程序暂停的时候你可以用Watch查看某个变量,按Ctrl+F7(Add Watch,添加查看)可以在查看列表(Watch List)中增加一个变量。在Watch中你可以查看变量或者表达式,指定数据的格式,甚至可以指示Delphi调用某些函数,显示函数的返回值。有一种快速查看模式,称为Local Variables(局部变量),按Ctrl+Alt+L能够显示这个窗体,里面是当前过程或函数的局部变量。Delphi还支持一种临时的求值模式(Evaluate/Modify),按Ctrl+F4显示求值框,你可以在这里输入一个变量或者表达式,计算其数值,对于变量还可以在运行时改变它的值,这样如果你已经发现数据有错,你可以修改它,让程序继续运行下去,就像这个数值就是程序得出的一样。检查(Inspect),是一种可以进一步查看变量信息的手段。把光标放在某个变量前,按Alt+F5显示检查窗。在这里可以看到有关这个变量的详细信息,包括:类型、值等,这对于类类型、记录类型尤其有用。和Evaluate/Modify一样,你也可以改变这些值。6. 调用堆栈(Call Stack)对于某些递归调用和复杂的嵌套调用来说,使用Call Stack功能能够方便的检查函数的调用情况。按Ctrl+Alt+S可以显示这个窗体,在最上面的是当前过程或函数,在最下面的往往是你的主程序。例如:TForm1.Button1Click(???);Project1这表示Project1调用了方法TForm1.Button1Click,由于其参数是一个对象(Sender:TObject),不能求值,所以用???表示。双击Project1可以看出在什么地方调用了TForm1.Button1Click(如果调用点没有源代码,则显示有源代码的第一行)。7. 高级调试功能上面所说的是常规的调试功能,Delphi还提供了很多高级调试功能。线程状态(Thread Status):显示当前程序中有多少线程在运行,各线程的状态是什么?参数是什么? 模块(Modules):显示当前进程使用了多少模块,其名称和地址是多少?这对于调试DLL时很有用。 CPU/FPU:在汇编语言层次显示代码,这能够更加精确地观察程序是如何运行的,各寄存器是怎么变化的。 进程附着(Attach Process):为了调试某些特殊程序(例如Windows 2000下的服务【Service】),允许先运行用户程序,再运行调试程序。 远程调试(Remote Debug):允许在一台计算机上运行用户程序,在另外一台计算机上运行Delphi,通过网络进行调试,这对于调试大型程序很有用,也能调试那些对系统有特殊要求的程序。 Delphi变量查看(Watch)/检查(Inspect)在程序暂停的时候你可以用Watch查看某个变量,按 Ctrl+F7(Add Watch,添加查看)可以在查看列表(Watch List)中增加一个变量。在Watch中你可以查看变量或者表达式,指定数据的格式,甚至可以指示Delphi调用某些函数,显示函数的返回值。有一种快速查看模式,称为Local Variables(局部变量),按 Ctrl+Alt+L 能够显示这个窗体,里面是当前过程或函数的局部变量。Delphi还支持一种临时的求值模式(Evaluate/Modify),按 Ctrl+F4 显示求值框,你可以在这里输入一个变量或者表达式,计 算其数值,对于变量还可以在运行时改变它的值,这样如果你已经发现数据有错,你可以修改它,让程序继续运行下去,就像这个数值就是程序得出的一样。检查(Inspect),是一种可以进一步查看变量信息的手段。把光标放在某个变量前,按Alt+F5显示检查窗。在这里可以看到有关这个变量的详细信息,包括:类型、值等,这对于类类型、记录类型尤其有用。和Evaluate/Modify一样,你也可以改变这些值。&
07-2110-2808-2008-0308-0207-2507-2504-2403-2602-25
阅读本文后您有什么感想? 已有23人给出评价!
名称大小下载eclipse调试时鼠标移动到变量上不显示值的问题 -
- ITeye技术网站
博客分类:
今天同事问一问题,就说在eclipse中调试时,鼠标移动到变量上不显示值,这个原来自己也遇到过,没注意,反正就使用ctrl+shift+i嘛,也可以的,刚查了一下,解决方法如下:
Window-&Preferences-&Java-&Editor-&Hovers 将[Variable Values]选择即可,如果第一个[Combined Hover]已经勾选,则将这个勾去掉,勾选[Variable Values]。如果还不行,就只能用ctrl+shift+i快捷键了。
浏览 14742
有用,正好遇到了!
呵呵 ,能解决问题就好
浏览: 458868 次
来自: 深圳
有用的东东,谢谢!
j_yo 写道谢谢eclipse中边debug,边动态修改变量值
1. debug开始,到达断点停下后,点左下角的增加视窗的按钮
2. 输入display,打开display视窗
3. 在display视窗中输入程序中使用的变量名,和你要对它的赋值操作
4. (比较关键)就是要圈选住这行代码,然后才能点击display视窗右上角的execute按钮
第4步,类似MySQL-Front中执行sql语句时的那个圈选操作。
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。为什么有时候调试代码的时候看不到变量的值。 - 讨论 - 高级语言虚拟机 - ITeye群组
& 上一页 1
现在有以下情况,我想跟一下SUN JDK的某个地方的代码想看看。但跟踪之后不能查看代码的情况。我用的是eclipse .但是有些代码又能查看到。不知道怎么回事。
下面是图。
不知道我说的这个问题和
http://hllvm./group/topic/25725
这个问题是不是有一定的关系。。希望大家帮讲解下。
哈哈,昨天我做培训的时候还说过这个…跟另外那帖没什么关系。这个问题很简单,就是你要调试的类的Class文件里没有包含LocalVariableTable属性表。在用Java源码编译器编译Java源码得到Class文件的时候,传-g参数就会有符号信息了。如果你遇到看不到局部变量信息的类你手上有源码的话,就加上-g再编译一遍吧
RednaxelaFX 写道哈哈,昨天我做培训的时候还说过这个…
跟另外那帖没什么关系。这个问题很简单,就是你要调试的类的Class文件里没有包含LocalVariableTable属性表。在用Java源码编译器编译Java源码得到Class文件的时候,传-g参数就会有符号信息了。
如果你遇到看不到局部变量信息的类你手上有源码的话,就加上-g再编译一遍吧
& eclipse 查看源代码是根据 LocalVariableTable 属性表查看的?那你的意思是我要把JDK的源代码重新编译一份啊?
而且为什么有的源代码他有 localvariable table 信息,有的没有呢?
原因撒迦说了,没有生成LocalVariableTable属性。这时候jdwp能在上下文找到变量的值,可是它不认识变量的名字啊,我来做个step by step就看的很清楚了。
public class A {
public static void foo(int a, String b, Object c) {
System.out.println(a + b + c);
public class B {
public static void foo(int a, String b, Object c) {
System.out.println(a + b + c);
public class T {
public static void main(String[] args) {
A.foo(1, "2", new Object());
B.foo(1, "2", new Object());
D:\Test&javac -g:lines A.java
D:\Test&javac -g B.java
IcyFenix 写道原因撒迦说了,没有生成LocalVariableTable属性。这时候jdwp能在上下文找到变量的值,可是它不认识变量的名字啊,我来做个step by step就看的很清楚了。
public class A {
public static void foo(int a, String b, Object c) {
System.out.println(a + b + c);
public class B {
public static void foo(int a, String b, Object c) {
System.out.println(a + b + c);
public class T {
public static void main(String[] args) {
A.foo(1, "2", new Object());
B.foo(1, "2", new Object());
D:\Test&javac -g:lines A.java
D:\Test&javac -g B.java
我感觉有问题。下面我依次写出来:
1:你开的开发开发环境是eclipse 吗?如果是的话,你先用命令行把代码编译了,然后再拷贝到eclipse里面吗?
2:如果你是按照上面的说法做的,那么我就可以得出,eclipse默认编译项目的时候都带有-g这个参数,不然我们自己调试自己的源代码的时候也会找不到LocalVariableTable而导致不能查看。
3:如果第二条我的假设成立,那么eclipse肯定有一个全局执行java命名的配置文件,那么这个文件在哪里?如何看?
4:就是你的回答还没有帮我解决的一点问题就是,为什么同一个rt.jar有些代码调试的时候有localvariableTable,而有的没有。难道sun的伙计不是全部编译的,而是一个文件一个文件编译的?再编译的时候可能忘了用-g(当然了,也有可能,因为可能早版本的java源代码不需要编译,所以就没编译,所以就没有localvariabletable,至于新版本新加的类可能有些也有localvariabletable,有些无。我想测试一下才能下结论)
5:就是谢谢你的热心回答。
还有一点。你的图片是怎么发出来的,我发图片是先放到blog里上传,然后再贴地址,但是看到你为了帮我解决这个问题,贴了两个图,应该不是用这么麻烦的方式吧,是不是javaeye有其他功能,可以快速贴图的。
如果你是贴图的方式和我一样。那么我真的万分感动。
不用javac,用ecj当然也可以,Eclipse里面也可以设置是否要生成LocalVariableTable属性,我写那2行命令行只是为了让你看清楚一些。eclipse的设置在这里(Add variable attributes to generated class files那个复选框):rt.jar里面是否都带有调试信息,我没有逐个类验证,不过我想当然地、不负责任地、拍个脑袋地说:应该是吧。你截图中的是equniox里面的类,不是rt.jar的。贴图……圈子貌似是没有贴图功能,呃,是不方便。我是在博客的草稿箱放了一个稿件,专业用来上传图片的。
Sun的JDK里,product的rt.jar是只有LineNumberTable没有LocalVariableTable的。也就是说跟不加-g或者加上-g:lines一样。
圈子的帖不能直接贴图这个我也觉得很奇怪…
xgj1988 写道2:如果你是按照上面的说法做的,那么我就可以得出,eclipse默认编译项目的时候都带有-g这个参数,不然我们自己调试自己的源代码的时候也会找不到LocalVariableTable而导致不能查看。
对的,Eclipse默认就是会让编译器带上调试信息的。配置的位置在上面IcyFenix的截图里有了。
xgj1988 写道3:如果第二条我的假设成立,那么eclipse肯定有一个全局执行java命名的配置文件,那么这个文件在哪里?如何看?
你做了一个错误的假设:Eclipse不是用javac来编译Java源码的,而是用它自己的编译器,名字叫ECJ。同样支持-g参数。配置的位置参考上一点。
xgj1988 写道4:就是你的回答还没有帮我解决的一点问题就是,为什么同一个rt.jar有些代码调试的时候有localvariableTable,而有的没有。
是都没有吧…
j2se/make/common/Defs.gmk
# Any debug build should include all debug info inside the classfiles
ifeq ($(VARIANT), DBG)
DEBUG_CLASSFILES = true
ifeq ($(DEBUG_CLASSFILES),true)
JAVACFLAGS_COMMON += -g
JAVACFLAGS
= $(JAVACFLAGS_COMMON) $(OTHER_JAVACFLAGS)
= $(JAVAC) $(JIT_OPTION) $(JAVACFLAGS) $(LANGUAGE_VERSION) $(CLASS_VERSION)
在debug build里才有-g。
你们的回答很精彩。我先一一说明一下:
1:我刚才根据LcyFenix给的图。逐步关闭上面的复选框,然后在调试确实有问题。而且如果把add line number attributes to generated class files 关闭之后,就不能下断点了(并不是不能调试,因为调试不仅仅包括下短点,个人理解根据JPDA的定义来看说的话。),所以我们的调试不会运行。
2:我把add variable attributes to generated class file 关闭之后,可以调试源代码,但是出现a can't be resolved ,注意,这里可能是我在最开始就没表述清楚,我这里说的不can't be resolved是我在eclipse里面用watch和inspect试图的时候就会can't be resolved ,但是在variables里面会显示出他的值,但是这样又有一个新问题。也就是a,b,c变量名变成了arg0,arg1,arg2这样的形式。所以可能IcyFenix也没太懂我的意思。
例子用的是IcyFenix的
public class A {
public static void foo(int a, String b, Object c) {
System.out.println(a + b + c);
public class B {
public static void foo(int a, String b, Object c) {
System.out.println(a + b + c);
public class T {
public static void main(String[] args) {
A.foo(1, "2", new Object());
B.foo(1, "2", new Object());
所以问题就是:
1:为什么variable下面可以看到a,b,c的信息,但是在watch和inspect就不行了?
2:就是RednaxelaFX给的最后的东西不太明白是什么。哈哈
引用j2se/make/common/Defs.gmk
Makefile代码&
# Any debug build should include all debug info inside the classfiles&&
ifeq ($(VARIANT), DBG)&&
& DEBUG_CLASSFILES = true&&
ifeq ($(DEBUG_CLASSFILES),true)&&
& JAVACFLAGS_COMMON += -g&&
JAVACFLAGS&&&& = $(JAVACFLAGS_COMMON) $(OTHER_JAVACFLAGS)&&
JAVAC_CMD&&&&& = $(JAVAC) $(JIT_OPTION) $(JAVACFLAGS) $(LANGUAGE_VERSION) $(CLASS_VERSION)
在debug build里才有-g。
& 上一页 1

我要回帖

更多关于 玩剑灵电脑配置 的文章

 

随机推荐