C++学习笔记8 C++函数的升级 下
2014-08-20 22:13
288 查看
1:C++中的函数重载:
函数重载(Function Overload)
<1>用同一个函数名定义不同的函数
<2>当函数名和不同的参数搭配时含义不一样
int func(int x)//一个int参数
{
return x;
}
int func(int x, int y)//两个int参数
{
return x+y;
}
int func(char * x)//一个 char* 参数
{
return strlen(x);
}
函数重载要满足下面至少一个条件:
<1>:参数个数不同
<2>:参数类型不同
<3>:参数顺序不同
int func(int a, const char* s)
{
return a;
}
int func(const char* s, int a)
{
return strlen(s);
}
上面两个是函数重载,因为参数的顺序不同
2:当函数默认参数遇上了函数重载:
int func(int x, int y)//两个int参数
{
return x+y;
}
int func(int x, int y, int z = 0)
{
return x+y;
}
int c = 0;
//c = func(1,2); //44 14 E:\C++源代码\main.cpp [Error] call of overloaded 'func(int, int)' is ambiguous
printf("c=%d\n",c);
发生错误提示,重载函数是模糊不清的
说明发生了二义性。
编译器调用重载函数的准则
将所有同名的函数作为候选者
尝试寻找可行的候选函数
<1>精确匹配实参(包括类型和个数)
<2>通过默认参数能够匹配
<3>通过默认类型转换匹配实参
匹配失败
<1>最终寻找到的可行候选函数不唯一,则出现二义性,编译失败。
<2>无法匹配所有候选者,函数未定义,编译失败。
函数重载的注意事项:
重载函数在本质上是相互独立的不同函数
重载函数的函数类型是不同的
函数返回值不能作为函数重载的依据
函数重载是由函数名和参数列表决定的。//非常非常重要
3:当函数指针遇上了函数重载会发生什么
int func(int x)//一个int参数
{
return x;
}
int func(int x, int y)//两个int参数
{
return x+y;
}
typedef int(*FUNC)(int a);
int main(int argc, char** argv) {
FUNC p = func;//根据重载规则挑选与函数指针参数列表一致的候选者
int c = 0;
c = p(1565);//调用第一个func函数
printf("c=%d\n",c);
getchar();
return 0;
}
函数重载与函数指针
当使用重载函数名对函数指针进行赋值时
• 根据重载规则挑选与函数指针参数列表一致的候选者
• 严格匹配候选者的函数类型与函数指针的函数类型
当把第一个func的返回类型 改为 void
运行函数会报错:
42 11 E:\C++源代码\main.cpp [Error] no matches converting function 'func' to type 'FUNC {aka int (*)(int)}'
说明候选者的函数类型必须与函数指针的函数类型一样
4:C++和C的相互调用:
在项目中融合C++和C代码是实际工程中不可避免的
虽然C++编译器能够兼容C语言的编译方式,但C++编译器
会优先使用C++的方式进行编译
利用extern关键字强制让C++编译器对代码进行C方式编译
如果在C++中调用C语言的内容则用 extern 方式
extern “c”
{
//要调用的内容
}
在C++和C语言都可以编译的写法
#ifdef _cPlusPlus
extern "c"{
#endif
//内容 函数的声明或者定义
#ifdef _cPlusplus
}
#endif
但是C++编译器不能以C的方式编译多个重载函数
总结:
函数重载是C++对C语言的一个重要升级
函数重载通过函数参数列表区分不同的同名函数
函数的返回值类型不是函数重载的依据
extern关键的关键能够实现C和C++的相互调用
函数重载(Function Overload)
<1>用同一个函数名定义不同的函数
<2>当函数名和不同的参数搭配时含义不一样
int func(int x)//一个int参数
{
return x;
}
int func(int x, int y)//两个int参数
{
return x+y;
}
int func(char * x)//一个 char* 参数
{
return strlen(x);
}
函数重载要满足下面至少一个条件:
<1>:参数个数不同
<2>:参数类型不同
<3>:参数顺序不同
int func(int a, const char* s)
{
return a;
}
int func(const char* s, int a)
{
return strlen(s);
}
上面两个是函数重载,因为参数的顺序不同
2:当函数默认参数遇上了函数重载:
int func(int x, int y)//两个int参数
{
return x+y;
}
int func(int x, int y, int z = 0)
{
return x+y;
}
int c = 0;
//c = func(1,2); //44 14 E:\C++源代码\main.cpp [Error] call of overloaded 'func(int, int)' is ambiguous
printf("c=%d\n",c);
发生错误提示,重载函数是模糊不清的
说明发生了二义性。
编译器调用重载函数的准则
将所有同名的函数作为候选者
尝试寻找可行的候选函数
<1>精确匹配实参(包括类型和个数)
<2>通过默认参数能够匹配
<3>通过默认类型转换匹配实参
匹配失败
<1>最终寻找到的可行候选函数不唯一,则出现二义性,编译失败。
<2>无法匹配所有候选者,函数未定义,编译失败。
函数重载的注意事项:
重载函数在本质上是相互独立的不同函数
重载函数的函数类型是不同的
函数返回值不能作为函数重载的依据
函数重载是由函数名和参数列表决定的。//非常非常重要
3:当函数指针遇上了函数重载会发生什么
int func(int x)//一个int参数
{
return x;
}
int func(int x, int y)//两个int参数
{
return x+y;
}
typedef int(*FUNC)(int a);
int main(int argc, char** argv) {
FUNC p = func;//根据重载规则挑选与函数指针参数列表一致的候选者
int c = 0;
c = p(1565);//调用第一个func函数
printf("c=%d\n",c);
getchar();
return 0;
}
函数重载与函数指针
当使用重载函数名对函数指针进行赋值时
• 根据重载规则挑选与函数指针参数列表一致的候选者
• 严格匹配候选者的函数类型与函数指针的函数类型
当把第一个func的返回类型 改为 void
运行函数会报错:
42 11 E:\C++源代码\main.cpp [Error] no matches converting function 'func' to type 'FUNC {aka int (*)(int)}'
说明候选者的函数类型必须与函数指针的函数类型一样
4:C++和C的相互调用:
在项目中融合C++和C代码是实际工程中不可避免的
虽然C++编译器能够兼容C语言的编译方式,但C++编译器
会优先使用C++的方式进行编译
利用extern关键字强制让C++编译器对代码进行C方式编译
如果在C++中调用C语言的内容则用 extern 方式
extern “c”
{
//要调用的内容
}
在C++和C语言都可以编译的写法
#ifdef _cPlusPlus
extern "c"{
#endif
//内容 函数的声明或者定义
#ifdef _cPlusplus
}
#endif
但是C++编译器不能以C的方式编译多个重载函数
总结:
函数重载是C++对C语言的一个重要升级
函数重载通过函数参数列表区分不同的同名函数
函数的返回值类型不是函数重载的依据
extern关键的关键能够实现C和C++的相互调用
相关文章推荐
- C++学习笔记5 C++之三目运算符的升级
- C++学习笔记1——C到C++的升级
- C++学习笔记7 C++函数的升级 上
- C++学习笔记3 C语言到C++的升级
- c++学习笔记(3.函数的升级)
- C到C++的升级(学习笔记)
- c++学习笔记(1.c到c++的升级)
- C++学习笔记(5)
- c++入门学习笔记--类和对象
- unix_c++学习笔记1
- c++学习笔记
- c++学习笔记 2005-9
- C++学习笔记--内存管理
- C++ 学习笔记 I/O流的常用控制符
- 高质量C++/C编程指南学习笔记(上)
- c++入门学习笔记指针篇
- C++学习笔记-类的继承(派生类)
- c++学习笔记(数组)
- C++学习笔记(1)——基类、派生类的对象空间
- C++学习笔记