|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
野指针,也就是指向不可用内存区域的指针。通常对这种指针进行操作的话,将会使程序发生不可预知的错误。
9 {' B. r8 d+ T# e“野指针”不是NULL指针,是指向“垃圾”内存的指针。人们一般不会错用NULL指针,因为用if语句很容易判断。但是“野指针”是很危险的,if语句对它不起作用。野指针的成因主要有两种:+ g; ~! N$ l: j; a2 Z+ \5 L, F
/ V9 K( I% }) Q6 e. n$ W7 b
一、指针变量没有被初始化。任何指针变量刚被创建时不会自动成为NULL指针,它的缺省值是随机的,它会乱指一气。所以,指针变量在创建的同时应当被初始化,要么将指针设置为NULL,要么让它指向合法的内存。
* ^& p" p1 O3 C# S* N
; I& F) ?. |* c" o- x二、指针p被free或者delete之后,没有置为NULL,让人误以为p是个合法的指针。别看free和delete的名字恶狠狠的(尤其是 delete),它们只是把指针所指的内存给释放掉,但并没有把指针本身干掉。通常会用语句if (p != NULL)进行防错处理。很遗憾,此时if语句起不到防错作用,因为即便p不是NULL指针,它也不指向合法的内存块。例:
# P( d! A+ U5 ~9 e( h: A) S
1 t* i6 A5 s" h9 uchar *p = (char *) malloc(100);+ h1 E( o9 p" M P, N: i1 v4 a
+ \1 ?& U, U+ B5 Z9 \7 @& gstrcpy(p, “hello”);
7 b+ e! V1 b) Q$ s# a6 Z/ Z
8 B: w/ {. h+ e# ^free(p); // p 所指的内存被释放,但是p所指的地址仍然不变
1 f. W& E. f. V( A( N: A1 D+ g$ L4 Y; J; p
if(p != NULL) // 没有起到防错作用
! Y- i: A [- u& G
# r4 Z+ j$ E- H' x9 \+ y; jstrcpy(p, “world”); // 出错
2 A1 d, D* A9 |) D" s( q& I( ?1 z9 r6 p" ~8 M S% f. ]
另外一个要注意的问题:不要返回指向栈内存的指针或引用,因为栈内存在函数结束时会被释放。
. n0 i2 G: z$ m& R" i2 _2 `" Q { |
|