Posted on 2011-03-07 11:06
點點滴滴 閱讀(576)
評論(0) 編輯 收藏 引用 所屬分類:
02 編程語言
/*什么叫空懸指針:指針所指向的存儲區(qū)的生存期以及結(jié)束,但是指針的生存期還沒有結(jié)束,導致
存儲區(qū)的數(shù)據(jù)已經(jīng)被釋放,指針所指的區(qū)域是個隨機值的這種錯誤。那么這個指針就叫空懸指針。
出現(xiàn)空懸指針的兩種常見情況:
1.函數(shù)返回一個自動型局部變量的地址,我以前就經(jīng)常出現(xiàn)這種情況
2.刪除一個動態(tài)分配的對象以后,沒有將指針指0,后面使用到這個指針的時候其實已經(jīng)指向一個
隨機值。
對2的一點補充,注意動態(tài)分配的時候,指針的生存期跟指針所指區(qū)域的生存期是兩個不同的概念。
指針的生存期從程序開始運行開始,結(jié)束于程序結(jié)束運行,指針本身的存儲區(qū)間是編譯的時候就
確定的,指針所指的動態(tài)分配的區(qū)間的生存期從new開始,到delete結(jié)束,所以如果調(diào)用delete后
沒有把指針指0就出現(xiàn)了空懸指針,此時很容易犯錯誤。
解決空懸指針的方法:1.對應情況1,函數(shù)返回一個靜態(tài)局部變量
2.對應情況2,調(diào)用delete以后,將指針指空。
*/
#include<iostream>
using namespace std;
int * add1(const int & a,const int &b)
{
int c=a+b;
cout<<"在函數(shù)add1的內(nèi)部結(jié)果為"<<c<<endl;
return &c;
}
//哈哈,在編譯這個函數(shù)的時候vc6.0給出了下面的警告:
//warning C4172: returning address of local variable or temporary
int * add2(const int &a,const int & b)
{
static int c=a+b;
cout<<"在函數(shù)add2的內(nèi)部結(jié)果為"<<c<<endl;
return &c;
}
int * add3(const int &a,const int &b)
{
int *p=new int;
*p=a+b;
cout<<"在函數(shù)add3的內(nèi)部結(jié)果為"<<*p<<endl;
return p;
}
void main()
{
int a=1,b=2,*p;
cout<<"調(diào)用add1返回一個空懸指針\n";
p=add1(a,b);
cout<<"指針所指的值為"<<*p<<endl;
cout<<"指針所指的值發(fā)生改變 了嗎?\n"<<(*p==3?"沒有改變":"改變")<<endl;
cout<<"調(diào)用add2可以避免返回一個空懸指針 "<<endl;
p=add2(a,b);
cout<<"指針所指的值為"<<*p<<endl;
cout<<"指針所指的值發(fā)生改變 了嗎?\n"<<(*p==3?"沒有改變":"改變")<<endl;
cout<<"調(diào)用add3可以避免返回一個空懸指針 "<<endl;
p=add3(a,b);
cout<<"指針所指的值為"<<*p<<endl;
cout<<"指針所指的值發(fā)生改變 了嗎?\n"<<(*p==3?"沒有改變":"改變")<<endl;
delete p;
p=0;
}