重载:不同上下文,不同含义
- 用同一个函数名定义不同的函数
- 当函数名和不同参数搭配时函数的含义不同
- 函数重载必然发生在同一个作用域
重载条件:参数的个数,类型,顺序至少一个不同
注意:默认参数函数函数相冲突
#include <stdio.h>
int func(int a, int b, int c = 0)
{
return a * b * c;
}
int func(int a, int b)
{
return a + b;
}
int main(int argc, char *argv[])
{
int c = func(1, 2);//error
return 0;
}
重载规则:精确匹配实参,默认类型参数,类型转换匹配实参
函数重载注意
- 本质:相互独立不同的函数
- 决定性:由函数名和参数列表决定函数重载
- 函数类型不一样????
- 函数返回值不能作为函数重载的依据
重载与函数指针
1,严格匹配对应的参数列表和函数类型
#include <stdio.h>
#include <string.h>
int func(int x)
{
return x;
}
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("c = %d\n", c);//1
return 0;
}
注意:
- 函数重载必然发生在同一个作用域
- 编译器通过参数列表或函数类型进行函数选择
- 无法通过函数名找到函数入口地址
#include <stdio.h>
int add(int a, int b) // int(int, int)
{
return a + b;
}
int add(int a, int b, int c) // int(int, int, int)
{
return a + b + c;
}
int main()
{
printf("%p\n", add);// erroe
return 0;
}
1用C++编译器中如何使用C编译器
2c或C++都用C编译能编译
#include <stdio.h>
extern "C"
{
#include "add.h"
}
int main()
{
int c = add(1, 2);
printf("c = %d\n", c);
return 0;
}
如下 c或C++编译时,都用此时都用C编译:
#ifdef __cplusplus //是否是C++编译器
extern "C"{
#endif
//C
#include "add.h"
#ifdef __cplusplus
}
#endif
C++不能以C的方式重载函数
C++编译方式将函数名和参数列表编译成目标名
C编译方式只将函数名作为目标名进行编译
编译方式取决于符号表中函数名的最终目标名