文章目录
- 前言
前言
我们都知道,函数重载即一个函数拥有了多个版本,我们使用时可以通过不同的数据类型区分我们调用的时哪一个重载函数,但编译器编译链接阶段对函数的调用时通过在符号表中寻找唯一名称来确定地址,c++时怎么解决了符号表中不能重命呢?
不同的编译器处理该问题底层处理不同,但逻辑大多相同,如下所说:
c++通过名称修饰区分解决
当编译器遇到函数重载时,它需要找到一种方法来区分这些重载函数。编译器内部会对每个函数进行签名或标识,这个签名是根据函数的参数列表生成的。这个签名是唯一的,因为它考虑了参数的数量、类型和顺序。
让我们通过一个简单的示例来解释这个过程。假设有以下两个重载函数:
void foo(int x);
void foo(double y);
编译器在处理这些函数时,首先会检查它们的参数列表。然后,它会根据参数的数量、类型和顺序来生成名称修饰。在这种情况下,编译器可能会采用类似以下的方式生成函数签名:
对于 void foo(int x);,签名可能是 foo_int,其中 int 表示参数的类型。
对于 void foo(double y);,签名可能是 foo_double,其中 double 表示参数的类型。
然后,在链接阶段,当编译器遇到一个 foo 函数的调用时,它会查找符号表,根据函数调用中使用的名称修饰来确定调用哪个具体的函数实现。
在链接阶段,编译器会根据函数调用中使用的名称修饰来查找符号表中的对应函数实现,从而区分不同的重载函数。