关键词: 函数重载与指针、 extern
关键字、 C和C++相互调用
1. 重载与指针
- 将重载函数名赋值给函数指针时
- 根据重载规则挑选与函数指针参数列表一致的候选者
- 严格匹配候选者的函数类型与函数指针的函数类型
编程实验:函数重载VS函数指针
#include <stdio.h>
#include <string.h>
int func(int i)
{
return i;
}
int func(int a, int b)
{
return a + b;
}
int func(const char* s)
{
return strlen(s);
}
typedef int(*PFUNC)(int a);
int main(int argc, char* argv[])
{
int c = 0;
PFUNC p = func;
c = p(1);
printf("%d\n", c);
return 0;
}
输出结果:
1
- 注意事项
- 函数重载必然发生在同一个作用域中
- 编译器需要用参数列表和函数类型进行函数选择,在函数重载遇见函数指针的时候需要匹配函数类型
- 无法直接通过函数名得到重载函数的入口地址
2. C++和C相互调用
- 实际工程在C++和C代码相互调用是不可避免的
- C++编译器能够兼容C语言的编译方式,但一般情况下会优先使用C++编译的方式
-
extern
关键字强制让C++编译器进行C方式的编译
extern "C"
{
// do C-style compilation here
}
问题:如何保证一段C代码不论在C编译器下或是在C++编译器下只会以C的方式被编译?
解决方案:
-
__cplusplus
是C++编译器内置的标准宏定义 -
__cplusplus
的意义:确保C代码以统一的C方式被编译成目标文件
#ifdef __cplusplus
extern "C" {
#endif
// C-Style Compilation
#ifdef __cplusplus
}
#endif
注意事项:
- C++编译器不能以C的方式编译重载函数
- 编译方式决定函数名被编译后的目标名
- C++编译方式将函数名和参数列表编译成目标名
- C编译方式只将函数名作为目标名进行编译
3. 小结:
- 函数重载是C++对C的一个重要升级
- 函数重载通过函数参数列表区分不同的同名函数
-
extern
关键字能够实现C和C++的相互调用,但是在extern
代码块中绝对不能有重载函数 - 编译方式决定符号表中的函数名和最终目标名
声明:此文章仅是本人在学习狄泰学院《C++深度解析教程》所做的笔记,文章中包含狄泰软件资料内容,一切版权归狄泰软件所有!
实验环境:gcc version 4.8.4 (Ubuntu 4.8.4-2ubuntu1~14.04.3)