<>1.生成可执行程序的过程
在C/CPP中,生成可执行程序需要经过预处理、编译、汇编、链接四个过程
<>1.1预处理
预处理阶段:
* 展开头文件、宏替换、条件编译、去掉注释
* 生成.i文件
<>1.2编译
* 检查语法
* 生成汇编代码
* 生成.s文件
<>1.3汇编
汇编阶段:
* 将汇编代码转化为二进制机器码
* 生成该文件的符号表
* 生成.o文件
<>1.4链接
链接:
* 合并段表
* 汇总符号表,找调用函数的地址,链接对应上,合并到一起
* 将所有的.o文件和静态库、动态库链接在一起生成可执行程序
<>2.CPP的处理
为什么cpp支持函数重载而c语言不支持函数重载?
通过可执行文件的生成过程我们知道,我们知道在汇编过程中,符号表里面会记录函数名和函数地址的映射关系。
//以下面的简单程序为例 void f(int a,double b) { printf("%d %f",a,b); } void f(double b,
int a) { printf("%f %d",b,a); }
查看函数对应的符号表
可以总结出cpp汇编中的函数名为:
Z 函数名长度 函数名 参数类型首字母1,首字母2…
<>3.C语言的处理
//以下面的程序为例 void f(int a,int b) { printf("%d %d",a,b); } void func(int c,int d)
{ printf("%d %d",c,d); }
查看符号表
C语言中符号表中,函数的地址同样是和函数名进行对应,但是C语言中符号表的函数名没有包含参数类型,函数名长度的信息。
这也解释了C语言为什么不支持函数重载。因为当相同的函数名被定义的时候,汇总符号表时就发生了错误。所以这类错误发生在函数的汇编阶段
<>4.CPP函数重载的类型
符号表中,函数名和地址一一对应。而CPP符号表中函数名是由:Z 函数名长度 函数名 参数类型首字母1,首字母2…
所以函数重载的类型有:
* 函数的参数;类型不同
* 函数参数的顺序不同
* 函数参数的个数不同