先看一段代码:
void function(int * exp)
{
.............
}
int main(int argc ,char * argv[])
{
int *tmp = NULL;
function(tmp);
.........
return 0;
}
笔者测试过,无论在function中怎么最tmp进行操作,都不会改变tmp为NULL的情况。原因是tmp是实参,exp是形参,即使是指针也不会改变这个事实,形参与实参最明显的区别就是作用域和生命周期不同。
tmp的作用域:在整个main函数中。
exp的作用域:在function函数中。
tmp的生命周期:从这个变量被定义到main函数执行完毕。
exp的生命周期:当funtion函数被调用到function函数执行完毕。
当tmp作为实参传入function函数时,程序会在内存中开辟一段新的空间,在这段内存中定义一个exp变量,然后把tmp的值赋值给exp,由于tmp是一个空指针,并没有内存空间,所以在function函数中对exp的操作并不会对tmp做出任何改变,当function函数执行完毕后,系统回收这样一段内存,对exp的所有操作都会消失(如果用malloc函数给exp分配了内存空间,这段内存空间会失去控制)。
如果这段代码是这样:
void function(int * exp)
{
.............
}
int main(int argc ,char * argv[])
{
int tmp_value = 2018;
int *tmp = &tp_value;
function(tmp);
.........
return 0;
}
这样,tmp指向了具体的内存空间,在function函数中,对 *exp进行赋值等操作是直接会改变*tmp的值(也就是tmp_value的值),但是如果改变了exp指向的内存空间,然后再对exp进行猛操作,便不会影响tmp,但是这样会使得程序不受控制,是不安全的。
以上是笔者自己的体会,如有错误,希望指出,共同学习进步。