传值和传址

在对函数传参时,一般分为传值传参和传址传参。
传值时就是在内存中新开辟一个空间,将值赋给这个新开辟的空间,其生命周期为该函数调用结束时释放该空闲,计算结果不影响原调用数据内存空间的值。
传址时同样新开辟一个空间,但不同的是将所用数据空间的内存地址存在新开辟的空间中,即指针,函数在数据处理过程中由于是指针,即对源数据进行操作,操作后结果影响原数据。

用以下例子加以说明:

//传值
void swap(int a, int b)
{
    int tmp = a;
    a = b;
    b = tmp;
}

int main()
{
    int a = 1;
    int b = 2;
    swap(a, b);
    printf("a=%d b=%d", a, b);
    system("pause");
    return 0;
}

输出为
这里写图片描述

//传址
void swap(int *a, int *b)
{
    int tmp = *a;
    *a = *b;
    *b = tmp;
}

int main()
{
    int a = 1, b = 2;
    swap(&a, &b);
    printf("a=%d b=%d", a, b);
    system("pause");
    return 0;
}

输出为:
这里写图片描述

由此可见,对于传值函数,传进去的值只是对于实际参数的一份临时拷贝,只在本函数内部有效。当函数调用完成后,形参变量的空间就被释放了,所以a,b的值没有改变。而用传址可以让函数和函数外边的变量建立起真正的联系,即函数内部可以直接操作函数外部的变量。

猜你喜欢

转载自blog.csdn.net/mmwwxx123/article/details/79900319
今日推荐