c语言 按值传递机制和按引用传递机制

在调用自定义函数时经常会遇到给被调用函数传递参数,参数的传递方式分为按值传递和按引用传递。

按值传递机制(pass-by-value mechanism):给函数传送变元时,变元值不会直接传递给函数,而是先制作变元值的副本,存储在栈上,这个副本用于被调用函数而不是用变元本身。这种方式被调用函数不能修改变元的值。

按引用传递机制(pass-by-value reference):此种方式是把变量的地址 接收为变元值,给函数传递地址时,它只是所传递地址的副本,而不是初始地址,但它仍然是一个地址,引用最初变量,和原地址指向同一块内存,函数可以通过这个地址直接访问原来的结构(这应该就是为什么指针作为参数时,可以修改指针指向的内容了吧)。库函数scanf_s()把地址作为参数就是这个道理,这种方式函数可以修改变元的值。

数组作为变元时,只是传递了该数组地址的副本,将数组名传递给函数,由于数组名引用了数组的起始地址,所以在数组名作为参数时可以按引用传递机制处理。

注意参数和变元的区别,eg:声明一个函数如下:int fun(int a,int *pnumber),其中的a和pnumber就是参数。

int main(void)
{    int b,c;
     b= fun(int c,int *p);
    statements..
}

其中c、p就是变元,这两个变元映射为参数a和pnumber。

通过一个例子说明一下按值传递和按引用传递,如下:

#include
#include
int sum(int numberAdd1);//函数声明
int PointerAdd1(int *number2);//函数声明
int Array( int row[]);//函数声明。把数组名作为参数,通过指针参数传递给函数时,只传递了该数组的地址副本,而没有传递数组。
int main(void)
{
 int i;
 int array[5]={1,2,3,4,5};
 int number=9;
 int *pnumber=&number;
 int number1;
 number1=sum(number);
 printf("The number1 value is %d.\nThe nubmer value is %d.\n ",number1,number);
 number= PointerAdd1(pnumber);
 printf("If transfer the address of number,the value of number is %d.\n",number);
 array[5]=Array(array);//将数组名array传递给函数Array().
 for( i=0;i<5;++i)
	{
printf("The value array[%-d] is %d.\n ",i,array[i]);
	}
 system("pause");
 return 0;
}
int sum(int numberAdd1)//sum()函数定义。
 {
	 numberAdd1=numberAdd1+1;///按值传递机制。验证参数值加1对变元值有无影响。
	 return numberAdd1;
 }
int PointerAdd1( int *number2)//PointerAdd1()函数定义。
	{
		return (*number2+=1);//按引用传递机制。验证参数值加1对变元值有无影响。
	}
int Array( int row[])//Array()函数定义
{
	int i=0;
	for(i=0;i<5;++i)
	{
		*row=*(row++)+1;按引用传递机制。验证参数值加1对变元值有无影响。数组传递为变元时,传递的是一个地址。
	}
	return row[5];
}

注:在地址作为参数时,如果不希望地址的引用值被修改,可以使用关键字const来修饰函数参数。这表示函数将传送给参数的变元值看做一个常量,指定函数不能修改该变元指向的值。
bool SendMessage(const char *pmessage)
{
//Code to send the message.//在进行编译时,编译器将确认函数体中的代码没有修改pmessage指向的内容,确保指向常量
                           //数据的指针变元应是安全的。如果有修改,编译器会报错。
return true;
}




你可能感兴趣的:(c语言)