C++函数提高
时间:2021-10-23
本文章向大家介绍C++函数提高,主要包括C++函数提高使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
函数提高
函数默认参数
在C++中,函数的形参列表中的形参是可以有默认值的。
语法:返回值类型 函数名 (参数 = 默认值){ }
示例:
int func(int a, int b = 10, int c = 10){
return a + b + c;
}
//1.如果某个位置参数有默认值,那么从这个位置往后,从左向右,必须都要有默认值
//2.如果函数声明有默认值,函数实现的时候就不能有默认参数
int func2(int a = 10, int b = 10);
int func2(int a, int b){
return a + b;
}
int main(){
cout << "ret = " << func(20,20) << endl;
cout << "ret = " << func(100) << endl;
system("pause");
return 0;
}
函数占位参数
C++中函数的形参列表里可以有占位参数,用来做占位,调用函数时必须填补该位置
语法:返回值类型 函数名 (数据类型){ }
示例:
//函数占位参数,占位参数也可以有默认参数
void func(int a,int){
cout << "this is func" << endl;
}
int main(){
func(10,10);//占位参数必须填补
system("pause");
}
函数重载
概述
作用:函数名可以相同,提高复用性
满足条件:
- 同一个作用域下
- 函数名相同
- 函数参数类型不同或者个数不同或者顺序不同
注意:函数的返回值不可以作为函数重载的条件
示例:
//函数重载需要在同一作用域下
void func(){
cout << "func 的调用" << endl;
}
void func(int a){
cout << "func(int a) 的调用" << endl;
}
void func(double a){
cout << "func(double a) 的调用" << endl;
}
void func(int a,double b){
cout << "func(int a,double b) 的调用" << endl;
}
void func(double a,int b){
cout << "func(double a,int b) 的调用" << endl;
}
//函数返回值不可以作为函数重载条件
int main(){
func();
func(10);
func(3.14);
func(10,3.14);
func(3.14,10);
system("pause");
return 0;
}
函数重载的注意事项
-
引用作为重载条件
-
函数重载碰到函数默认参数
//1.引用作为重载条件
void func(int &a){
cout << "func(int &a)调用" << endl;
}
void func(const int &a){
cout << "func(const int &a)调用" << endl;
}
//2.函数重载碰到函数默认参数
void func2(int a,int b = 10){
cout << "func2(int a,int b = 10)调用" << endl;
}
void func2(int a){
cout << "func2(int a)调用" << endl;
}
int main(){
int a = 10;
func(a); //调用无const
func(10); //调用有const
//func2(10); //碰到默认参数有歧义,需要避免
system("pause");
return 0;
}
原文地址:https://www.cnblogs.com/shumild/p/15449793.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- flink实战-使用自定义聚合函数统计网站TP指标
- 详解flink中Look up维表的使用
- 聊聊flink 1.11 中的随机数据生成器-DataGen connector
- flink实战教程-集群的部署
- Flink实战教程-自定义函数之标量函数
- Flink实战教程-自定义函数之TableFunction
- Flink教程-flink 1.11 流式数据ORC格式写入file
- Flink教程-使用sql将流式数据写入文件系统
- flink教程-flink 1.11 集成zeppelin实现简易实时计算平台
- flink教程-详解flink 1.11 中的CDC (Change Data Capture)
- flink教程-基于flink 1.11 使 sql客户端支持执行sql文件
- flink教程-详解flink 1.11 中的JDBC Catalog
- flink教程-flink modules详解之使用hive函数
- 面试iOS 机会在自己手中
- Flink教程-将流式数据写入redis