传值和传址其实是完完全全一模一样的!!!
举个例子:
#include<stdio.h>
void assign(int a)
{
a=5;
}
int main(int argc,char* argv[])
{
int a=0;
assign(a);
printf("%d",a);
}
大家知道,输出结果肯定不变,a还是等于0;
第二个例子:
#include<stdio.h>
#include<stdlib.h>
void assign2(int* a)
{
a=(int*)malloc(sizeof(int))
}
int main(int argc,char* argv[])
{
int* a=NULL;
assign(a);
printf("%p",p);
}
在这里强调一个知识:当指针指向NULL的时候实际上是0×00000000
这个地址在分配地址的时候是不会被分配出去的。
这样结果又是怎样呢?
永远都是00000000!!
为什么呢?明明是传址啊,而且在函数中已经开辟了空间啊。
让我们再更改一下:
#include<stdio.h>
#include<stdlib.h>
void assign2(int* a)
{
a=(int*)malloc(sizeof(int))
printf("%p ",a);
}
int main(int argc,char* argv[])
{
int* a=NULL;
assign(a);
printf("%p",a);
}
运行结果为:006EAb00 00000000
这意味着在函数中已经成功开辟,但是没有传出来。
在第一个例子中大家明白,在调用函数的时候实际上是用了a的一个拷贝,并不是原来的a,所以更改的是a的拷贝并不是a,故而a没有变。
在第二个和第三个例子中呢?看似传址,实际上也是在传值!!只不过传的是地址变量。什么意思呢?在调用函数的时候实际上传的还是a的一个拷贝。比如原来的a指向00000000,调用函数的时候只不过传的是另外一个指向00000000的a,也就是此时又两个指向00000000的指针!而这个拷贝改了,a却没有改。
这样的话要怎么改才行呢?
大家肯定知道第一个怎么改:
#include<stdio.h>
void assign(int* a)
{
*a=5;
}
int main(int argc,char* argv[])
{
int a=0;
assign(&a);
printf("%d",a);
}
也就是把指向a的指针传过去。
那么从这个角度出发,第二个第三个怎么改呢?
自然是吧指向a的指针的指针传过去咯!!
#include<stdio.h>
#include<stdlib.h>
void assign2(int* a)
{
a=(int*)malloc(sizeof(int))
}
int main(int argc,char* argv[])
{
int* a=NULL;
assign(a);
printf("%p",p);
}
在这里强调一个知识:当指针指向NULL的时候实际上是0×00000000
这样结果又是怎样呢?
永远都是00000000!!
为什么呢?明明是传址啊,而且在函数中已经开辟了空间啊。
让我们再更改一下:
#include<stdio.h>
#include<stdlib.h>
void assign2(int** a)
{
*a=(int*)malloc(sizeof(int))
printf("%p ",*a);
}
int main(int argc,char* argv[])
{
int* a=NULL;
assign(&a);
printf("%p",a);
}
这样,运行后就会得到两个一样的地址了!!