传址调用和引用调用的区别

传地址调用和传引用调用的区别

相同点:
传引用和传地址,原理上都是将参数变量的地址传递给被调函数。所以在函数内部修改参数的值时,均可返回修改之后的结果给调用者。

不同点:
引用一定会指向一个对象,而指针可能为空(NULL); 传引用时,系统对传过来的参数不会有任何额外开销,直接使用原始变量的内存空间。
传引用时,函数参数需要写做T&a; 调用函数时直接传递对象本身;在函数内赋值的时候,直接对a赋值即可。
传地址时,函数参数需要写作T*p;调用函数时需要传入对象地址; 赋值时需要对*p赋值。
总结
从以上对比可以得知,传引用调用比传地址调用更为简单高效。之所以保留传地址调用,主要是为了兼容C语言的代码。在C++编程时,应尽量以传引用代替传地址。
————————————————
版权声明:本文为CSDN博主「Java星」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/yangxingpa/article/details/77856370

以下是我在学习过程中遇到的传递地址调用的程序,自己写了和引用传递调用的函数作对比,c++不精通,如果那里错了,还望指正,谢谢。

#include <iostream>
using namespace std;

//void splitFloat( float a,int &intPart, float &floatPart )
//{
//	intPart = ( int )( a );
//	floatPart = a - intPart;
//}

void splitFloat( float a,int *intPart, float *floatPart )
{
	*intPart = static_cast< int >( a );
	*floatPart = a - *intPart;
}

void add_Ref( int &x, float &y)
{
	x = 13;
	y = 14;
}
int main()
{
	cout << "Enter 3 float point numbers:" << endl;

	float x,f;
	int n;
	cin >> x;
	splitFloat( x, &n, &f);//传地址调用:函数参数为地址,需要定义指针指向这个地址
	cout << "Integer: " << n << "  Float: " << f << endl;//输出整数部分和小数部分
	add_Ref( n, f);			//传引用调用:函数参数为变量名,函数形参定义为引用
	cout << "n: " << n << "  f: " << f << endl;//输出13,14

}
发布了11 篇原创文章 · 获赞 7 · 访问量 5253

猜你喜欢

转载自blog.csdn.net/qq_35591140/article/details/105572180