C語言野指針總結
1. 定義“野指針”不是 NULL 指針,是指向“垃圾”內存的指針。人們一般不會錯用 NULL 指針,因爲用 if 語句很容易判斷。但是“野指針”是很危險的,if 語句對它不起作用。
2. 成因
“野指針”的成因主要有兩種:
(1) 指針變量沒有被初始化。 任何指針變量剛被創建時不會自動成爲 NULL 指針,它的缺省值是隨機的,它會亂指一氣。所以,指針變量在創建的同時應當被初始化,要麼將指針設置爲 NULL,要麼讓它指向合法的內存。例如
char *p =NULL;
char *str = (char *) malloc(100);
(2)指針 p 被 free 或者 delete 之後,沒有置爲 NULL,讓人誤以爲 p 是個合法的指針。
(3) 指針操作超越了變量的作用範圍。示例程序如下:
classA {
public:
void Func(void){
cout <<“Func of classA” << endl;
}
};
void Test(void){
A *p;
{
A a;
p = &a; // 注意 a的生命期
}
p->Func(); // p 是“野指針”
}
函數 Test 在執行語句 p->Func()時,對象 a 已經消失, 而 p 是指向 a 的, 所以 p 就成了 “野指針” 。