如何调试你的C#程序(3)
发表于:2007-06-30来源:作者:点击数:
标签:
第三步:调试你的程序;(下面的出现的将是调试程序的时候所有的代码,请注意我的注释是加在后面的) (cordbg)sh 18 001: /* 002: @#Data:2001-12-13 003: @#Author:龙山文化 004: @#One Csharp Test Program 005: */ 006: using System; 007: class Test_1
第三步:调试你的程序;(下面的出现的将是调试程序的时候所有的代码,请注意我的注释是加在后面的)
(cordbg)sh 18
001: /*
002: @#Data:2001-12-13
003: @#Author:龙山文化
004: @#One Csharp Test Program
005: */
006: using System;
007: class Test_1
008: {
009: static void Main()
010: {
011: string str;
012:* Console.WriteLine("Please Enter Your Name. Thanks!");
013: str=Console.ReadLine();
014: Console.WriteLine("------------------------------------\r\n");
015: Console.WriteLine("Dear "+str+", Welcome To Csharp@#s World!\r\n");
016: Console.WriteLine("------------------------------------\r\n");
017: }
018: }
/*"sh" 命令是查看被调试程序源代码的,其实这个源代码还是从Test-1.cs中装载的,如果你的Test-1.cs不存在的话,在装载被调试的程序的时候会出现如下错误代码:
"Error loading source file @#E:\Cs\Test-1.cs@#: File not found"
当然程序还是可以运行的。只不过原来的最后一行的C#代码显示,变成了汇编代码的显示。关于汇编方式的显示我将在后面的文章中加以介绍。
*/
(cordbg) b 12
Breakpoint #1 has bound to E:\Cs\Test-1.exe.
#1 E:\Cs\Test-1.cs:12 Main+0x0(il) [active]
… …
/*通过b 命令设置了程序断点,天啦!你不要告诉我连什么是断点都不知道哟。如果你不知道的话,那么老大你还是不要看了吧。
设置断点调试程序调试程序最重要的一个方法
b 命令也可以查看所有已经被设置的断点,如下所示
*/
(cordbg) b
#1 E:\Cs\Test-1.cs:12 Main+0x0(il) [active]
#2 E:\Cs\Test-1.cs:13 Main+0xa(il) [active]
#3 E:\Cs\Test-1.cs:14 Main+0x10(il) [active]
(cordbg) con
Please Enter Your Name. Thanks!
break at #2 E:\Cs\Test-1.cs:13 Main+0xa(il) [active]
013: str=Console.ReadLine();
/*
con 命令表示继续执行程序代码,一直执行到下一个断点,本来程序被装载后默认设置了一个断点,在使用sh命令察看源代码的地方某行代码的序号被加了一个"*",这行代码就算是系统默认的断点设置。
另外有个"next" 命令也可以用来调试,但是表示执行到下一行,而不是下一个断点行。请注意区分,你也可以实际的操作来看看具体的效果
*/
(cordbg) con
龙山文化
break at #3 E:\Cs\Test-1.cs:14 Main+0x10(il) [active]
014: Console.WriteLine("------------------------------------\r\n");
(cordbg) p str
str=(0x00ba3414) "龙山文化"
/*
上面的调试代码利用 con命令执行到下一个断点:获得了一个系统输入字符串"龙山文化"
并且利用"p" 命令打印出了变量"str"中的数据,在调试程序的时候打印程序中的程序变量是很关键的动作。
*/
(cordbg) con
------------------------------------
Dear 龙山文化, Welcome To Csharp@#s World!
------------------------------------
[thread 0x5fb0] Thread created.
[thread 0x59a8] Thread exited.
Process exited.
/*
con执行下一个断点后,程序运行到结束。
*/
到这步为止,一个最简单的C#程序就通过Cordbg通过最简单的方式调试完成了,在后面的文章中我将会给你展示更加复杂的程序的调试
原文转自:http://www.ltesting.net