如何正确使用debug

一、Debug课程引言

我们在写程序的时候,会经常出现一些问题也叫bug(如程序运行报错,结果与预期不符等),面对这些问题,特别是对于初学者而言,会有很大的困扰,在解决问题的过程中会消耗大量的时间,因为没有掌握解决问题的方式。

所以我觉得有必要开发一套课来提高大家解决问题的能力,因为不管对于现在学习而言,还是对于日后的工作而言,解决bug是一个非常重要的能力。因为bug无处不在,可以说bug是伴随我们开发的伴侣,只有我们能征服这些bug,才能征服开发工作。

二、Bug分类

程序中的错误大致分为两种,编译时错误和运行时错误。

1. 编译时错误

这种问题基本都是一些语法错误,哪里有红色波浪线,哪里就有问题。

a. 类名,方法名,变量名写错了

b. 标点符号写错了

c. 括号不匹配

d. 修改了代码,没有保存

e. 方法中少了return语句

以上这些问题都是最最最最最最基本的语法格式问题,必须知道怎么解决,这不是我们此次课程的重点。

2. 运行时错误

程序运行时出现的bug才是我们课程的重点。

程序运行时出现错误的原因就比较复杂了,有下面几种情况

a. 程序不能正常执行,报错(如NullPointerException)

b. 程序可以正常执行,但结果不对

上述这些bug出现的原因就比较复杂,特别是那种看起来没问题,执行也没报错,但是结果就是不对的代码,很头疼。这个时候就需要我们用到专业的Debug工具来调试程序。

三、Debug应用

为了让大家能够熟悉debug调试工具,提高解决bug的能力,在基础班的各个阶段分别设置一个有bug案例,用debug调试的方式来查找问题。

有句老话叫“授人以鱼不如授人以渔”,通过学习这些案例,希望大家以后遇到问题首先能够自己解决。大家毕业之后工作了,拿着别人的工资,那个时候遇到了bug,谁能帮你解决,只能自己想办法解决。

1. Debug案例1

//基本类型作为参数

publicstaticvoid show(int a){

a=a+1;

}

//引用类型作为参数

publicstaticvoid show(int[] arr){

arr[0]+=1;

}

2. Debug案例2

/*

* 分析以下需求,并用代码实现(循环,if):

(1)打印1到100之内的整数,但数字中包含9的要跳过

(2)每行输出5个满足条件的数,之间用空格分隔

(3)如:1 2 3 4 5

*/

publicstaticvoid function3(){

int count=0;

for(int i=1;i<100;i++){

if(!(i%10==9||i/10%10==9)){

System.out.print(i+" ");

count++;

}

if(count%5==0){

System.out.println("");

}

}

}

执行结果如下:在38和40之间多了一个空行

.....省略......

34 35 36 37 38

40 41 42 43 44

.....省略......

3. Debug案例3

public class Fu {

int a;

public Fu() {

a=20;

show();

}

public void show(){

System.out.println(a);

}

}

public class Zi extends Fu{

int a;

public Zi() {

a=20;

}

public void show(){

System.out.println(a);

}

public static void main(String[]args){

Zi z=new Zi();

z.show();

}

}

打印结果为:

0

20

4. Debug案例4

下面字符串中”java”出现的次数

“sunjavahpjavaokjavajjavahahajavajavagoodjava”

String s ="sunjavahpjavaokjavajjavahahajavajavagoodjava";

int count = 0;

int index=0;

while (s.indexOf("java") != -1) {

index = s.indexOf("java", index);

if (index != -1) {

index = index + 1;

count++;

}

}

System.out.println(count);

5. Debug案例5

public static void main(String[] args) {

getDir(newFile("C:\"));

}

/*

* 打印输出指定目录下所有的.java文件(包含子目录)

*/

public static void getDir(File dir){

File[] files = dir.listFiles();

for(File f:files){

if(f.isDirectory()){

getDir(f);

}else{

if(f.getName().endsWith(".java")){

System.out.println(f);

}

}

}

}

Exception in thread "main" java.lang.NullPointerException

atcn.itcast.demo1.Demo4.getDir(Demo4.java:15)

atcn.itcast.demo1.Demo4.getDir(Demo4.java:17)

atcn.itcast.demo1.Demo4.getDir(Demo4.java:17)

atcn.itcast.demo1.Demo4.main(Demo4.java:7)

(0)

相关推荐