本文主要是介绍深入了解传址和传值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
我们一般使用函数的返回值来进行校验,如果要使用函数的返回值,一般采用出参(传址参数)的形式;而函数的传值和传址只需记住一句话——”函数的形参是实参的拷贝“因此传指针和传一般变量一样,传的都是实参的副本,而由于指针支持运算比较多(解引用,+ ,- ……)才使得可以对指针所指向的存储区内容进行实际修改;传实参本身而非副本的情况只有在C++的传引用中出现过
就可以推出函数是不是改变了实参,下面是几个例子相信你看完例子就会彻底搞懂传址;
之前讲的有错,改了一下,如果有疑问,请多多交流;
#define _crt_secure_no_warnings 1
#include<stdio.h>
#include<stdlib.h>
//临时指针变量在函数运行完,生命周期结束。不改变主函数的参数值;
void fun(int* p1)
{int data = 1;p1 = &data;//给p存储的值赋值为date的地址,null=&date;函数只是对拷贝的P的值进行了修改,而没有通过地址访问P并进行值修改,表面看起来是址传递,实质是值传递//应该传p的地址,进而对p的值进行修改;printf("%d\n",*p1);
}
int main()
{int* p = 0;fun(p);//拷贝了p的值(p存储的地址null)//函数只是对拷贝的P的值进行了修改,而没有通过地址访问P并进行值修改,表面看起来是址传递,实质是值传递//应该传p的地址,进而对p的值进行修改;printf("%d", *p);system("pause");return 0;
}void fun(int* p1)
{int data = 1;*p1 = data; //解引用null地址,(*null=date)没有访问权限无法完成
}
int main()
{int* p = 0;fun(p); //拷贝了p的值(p存储的地址null)printf("%d", *p);system("pause");return 0;
}
关于指针传递的联系2:函数返回临时变量的地址
void fun(int* p1)
{int data = 2;*p1 = data; //解引用a地址并赋值为date,*(&a)=date;
}
int main()
{int a = 0;fun(&a); //拷贝了a的地址printf("%d", a);system("pause");return 0;
}关于指针传递的联系3:传递给函数的是指针的指针
void fun(int** p1)//参数二级地址存储指针的地址
{int data = 3;*p1 = &data; //p1是二级指针存储一级指针,解引用一次就取出了一级地址内的内容,*p1相当于 *(&p)即p的内容,赋值为date的地址,p=&date;(使p指向date)给以p为地址的空间里放了date的地址里(地址—>内容修改) 一级地址指向date
}
int main()
{int* p = 0;int **p2 = 0;fun(&p); //拷贝了p的地址;参数为一级指针的地址,相当于二级指针存储的内容;p2 = &p; // 让p2存储p的地址 p中存储了&dateprintf("%d", **p2);system("pause");return 0;
}
这篇关于深入了解传址和传值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!