如何理解数据结构中的引用参数(&)

来源:互联网 发布:apache kylin教程 编辑:程序博客网 时间:2024/05/22 05:09
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://89wyz.blog.51cto.com/950360/346882

C语言中的&是取变量逻辑地址的操作与变量本身所在的物理地址没有关系,它直接与变量的值相关,即使变量本身所在的物理地址改变,&操作也没有影响,&操作取值不会改变.

*是取变量物理地址的操作即使变量本身所在的逻辑地址改变,&操作也没有影响&操作取值不会改变.但是 一旦物理地址中的数据改变,*操作所得的数据也将随之改变.

这就像是在一栋楼房中找人,&按入住人的名字找人,*按门牌号找人虽然同是找人,但还是有本质上的区别的.当且仅当门牌号对应的人按入住人姓名找的人相同的时候找到的人才是同一个人.

 

&的用法和含义,见下面的例子:

main()

{ int i=3,j=5;

change(i,j);

printf("i1=%d %d ",i,j);

}

void change(int n, int m)

{ n=n+m;

printf("n=%d,m= %d ",n,m);

}

运行的结果为:

i1=35

n=8, m=5

 

现把上面的程序改为:

main()

{ int i=3,j=5;

change(&i,j);

printf("i1=%d %d ",i,j);

}

void change(int &n, int m)

{ n=n+m;

printf("n=%d,m= %d ",n,m);

}

运行的结果为:

i1=85

n=8, m=5

为什么会产生这样的结果?

 

C语言中的&是取变量地址的操作,在执行main(){ int i=3,j=5; 时, 操作系统(os)会对变量i,j分配内存单元,如i的地址是2800os只管理2800的单元,它并不知变量i,执行i=3;则2800单元中的内容是3,用符号(2800)=3表示,执行调change函数,i的地址2800传递给n&n2800,在执行n+m,则2800单元中的内容变成8,(2800)=8,再退回到main时,执行 printf("i1=%d %d ",i,j);则应该把2800单元中的内容输出(注意在os中没有变量的处理,只有对地址的管理),这时2800单元中的内容已变成8,所以输出是i1=85。我们注意到此时in实际上是共用的同一个地址,所以n的改变会影响上一级的模块中的i变量,即参数的双向传递!

实际中由于c语言并不是一种非常严谨的语言,它本身并不提供参数的双向传递功能,是用地址来实现的。在数据结构的课程中,以后只要发现参数中有&符号,它就是双向传递,即既有输入又有输出,可以把它理解成全局量,但全局量在整个系统的所有模块都起作用,&只在定义的函数(模块)中起作用,可以理解为局部的全局量

&符号我想不出有很好和严谨的描述方法,如果一定要与某些东西类比,在pascal中的VAR是最接近的, Proc change(VAR n:integer, m:integer)    

 

 

关于函数参数的传递方式:

值传递:只是将参数值copy函数中,因此在函数中无法修改该参数的值。修改的只是传入参数的一份copy.

引用传递:将参数地址传给函数,因此在函数中能修改该参数的值


 

  1. #define Fun_No_Error 1
  2. #include <stdio.h>
  3.  
  4. /*
  5.     该程序用来验证,函数中参数的值传递,与引用传递的不同点
  6. */
  7.  
  8.  
  9. //Value deliver
  10. void FucValue(int a,int b)
  11. {
  12.     printf("\nAddress of a is %d",&a);
  13.     printf("\nAddress of b is %d",&b);
  14.     a=a+1;
  15.     b=b+1;
  16.     
  17. }
  18. //refer deliver
  19. void FucRefer(int &a,int &b)
  20. {
  21.     printf("\nAddress of a is %d",&a);
  22.     printf("\nAddress of b is %d",&b);
  23.     a=a+1;
  24.     b=b+1;
  25. }
  26.  
  27. int main(int argc,int argv[])
  28. {
  29.     int input1,input2,input3,input4;
  30.     printf("Please input two integer:");
  31.  
  32.     scanf("%d",&input1);
  33.     scanf("%d",&input2);
  34.     printf("\nAddress of input1 is %d",&input1);
  35.     printf("\nAddress of input2 is %d",&input2);
  36.     FucValue(input1,input2);
  37.     printf("\ninput1=%d\ninput2=%d",input1,input2);
  38.  
  39.     printf("\nPlease input two integer:");
  40.     scanf("%d",&input3);
  41.     scanf("%d",&input4);
  42.     printf("\nAddress of input1 is %d",&input3);
  43.     printf("\nAddress of input2 is %d",&input4);
  44.     FucRefer(input3,input4);
  45.     printf("\ninput1=%d\ninput2=%d",input3,input4);
  46.     
  47. }
  48.  
  49.  

 

本文出自 “sirius” 博客,请务必保留此出处http://89wyz.blog.51cto.com/950360/346882

原创粉丝点击