如下面所示的这个程序,按照道理 cChar应该是局部变量,在函数调用结束时,就应该销毁了,为什么还能返回呢? 这是因为,在函数结束的时候,销毁的只是局部变量,但是该局部变量指向的这个内存单元仍然存在,就是说aaaaaaaa在内存单元中仍然存在,所以返回实 际存在的内容是不会有问题的。
注意:是不能,返回指向临时变量的指针,而不是,不能返回一个临时指针变量。
同时,内存单元是可以被覆盖的,详情见程序:
char* set()
{
char* cChar = new char[10];
cChar = "aaaaaaaaa";
return cChar;
}
int _tmain(int argc, _TCHAR* argv[])
{
char* temp = set();
temp = "bbbbbbbb";
cout << temp << endl;
return 0;
}
*********************************************************************************************************************************************************
double* treble(double data)
{
double result = 0.0;
result = 3.0*data;
return &result;
}
仔细分析一下,result是作用域在treble函数中的局部变量。当函数执行结束后。变量result会被析构。其原先占用的内存区域已经被系统回收,可以存储任何数据。而返回的指向该地址的指针也失去了其原有的意义。因此我们得到这样一条准则:
永远不要从函数中返回局部自动变量的地址。