C++函数重载---底层实现原理

为什么要重载?:

       C++为了致力于简化编程,能通过函数重名来打到简化编程的目的。 C++允许在同一范围中声明几个功能类似的同名函数。可以提高开发效率,增加可读性。

对于不同的数据类型取绝对值,需要定义不同的函数

int iabs(int a)
{
	return a>0 ? a:-a;	
}

double fabs(doule a)
{
	return a>0 ? a:-a;
}

重载规则:

       1、函数名相同

       2、函数形参个数、顺序、类型不同

同时符合以上两个条件可构成重载,返回值不同不可以构成重载。

底层实现:

       C++利用命名倾轧(name mangling)技术,来改名函数名,区分参数不同的同名函数。命名倾轧是在编译阶段完成的。

C++定义同名重载函数:
C++函数重载---底层实现原理_第1张图片
底层实现:用nm命令查看目标文件的符号清单
C++函数重载---底层实现原理_第2张图片
由上图可得,d代表double,f代表float,i代表int,加上参数首字母以区分同名函数。

extern “C”:

       C++要实现对C语言的完全兼容。首先要语法兼容,其次是C库兼容。

       C++编写的代码,若去调用C编出来的库,是行不通的,因为C代码编译并不会发生命名倾轧行为,而C++代码编译会产生命名倾轧行为,所以函数名不匹配,则无法调用到C库中的函数。

       消除倾轧的方法,在C++代码包含C库的头文件,加入extern “C”。可在linux中自行编译一个C库,C++代码去调用,来证明无法链接到库函数。

extern "C"{			//让里面的内容不发生倾轧行为
......//例如:#include "head1.h"
}

       总之一句话,倾轧是C++为了实现函数重载而设计的,不倾轧的extern “C”则是为了兼容C而后实现的。

你可能感兴趣的:(C++函数重载---底层实现原理)