(1)、程序源代碼中的語法錯誤。這類錯誤是最容易檢查出來的。例如:在 C 語言中沒有定義某個變量就使用該變量。源程序舉例如下:
void main( )
{
int n1 = 50 ; /* 定義了壹個整型變量 n1,並賦初值為 50 */
printf("n1 = %d\tn2=%d\n", n1, n2) ; /* 輸出變量 n1、n2 的值 */
}
由於在使用 printf 語句之前並沒有定義 n2 變量,故該程序在使用編譯器對源程序進行編譯時會出現語法錯誤。
(2)、程序源代碼中的警告錯誤。這類錯誤就不像(1)中那樣容易檢查出來。通常的情況有:數組越界、或者是雖然定義了某個變量,但是未對其進行初始化就引用它,等等。這些都會引起程序莫名其妙的錯誤。而這些錯誤會加大程序的調試難度。源程序舉例如下:
程序壹、數組越界問題的舉例
void main( )
{
int a[100] ; /* 定義壹個數組元素個數為 100 的整型數組 a,正確的下標範圍是:a[0] - a[99] */
a[100] = 500 ; /* 對數組下標元素 a[100] 進行賦值為 500,該錯誤就屬於數組越界錯誤 */
}
程序二、雖然定義了某個變量,但是未對其進行初始化就引用它的舉例
void main( )
{
int i, sum ;
for( i = 0 ; i <= 100 ; i ++ )
sum += i ;
}
該程序的功能是:將變量 i 的值從 0 到 100 之間進行循環,求累加和,並將結果保存在變量 sum 中。由於變量 sum 在進入 for 循環之前並未將其清零(sum = 0),故該程序會隨著 C 語言的編譯器的不同、以及計算機操作系統的不同(Windows、或者是 Linux),而導致該程序的運行結果也是隨機的。
程序壹、以及程序二的錯誤就是屬於警告錯誤。C 語言編譯器在對這類程序進行編譯時,並不檢查該程序中是否有數組越界現象、或者是雖然定義了某個變量,但是未對其進行初始化就進行引用的檢查。這類錯誤,用戶就比較難於調試。
至於說到底需要多長時間才能夠將自己編寫的源程序全部調試通過,這個因人而異。編程經驗豐富的人員花費的時間就會短壹些。反之,調試程序所花費的時間就會長壹些。