C++简明讲解缺省参数与函数重载的用法
目录
- 一、缺省参数
- 1.1缺省参数概念
- 1.2缺省参数分类
- 二、函数重载
- 2.1函数重载概念
- 2.2名字修饰
一、缺省参数
缺省参数形象来说就是"备胎"。
1.1缺省参数概念
缺省参数是声明或定义函数时为函数的参数指定一个默认值。在调用该函数时,如果没有指定实参则采用该默认值,否则使用指定的实参。
#include<iostream> void P(int a = 3) { printf("%d", a); } int main() { P();//打印默认值 3 P(1);//打印传送的值 1 return 0; }
1.2缺省参数分类
1.全缺省参数
void P(int a = 3,int c = 1,int b = 2) { printf("%d", a); printf("%d", b); printf("%d", c); }
二、函数重载
2.1函数重载概念
函数重载:是函数的一种特殊情况,C++允许在同一作用域中声明几个功能类似的同名函数,这些同名函数的形参列表(参数个数 或 类型 或 顺序)必须不同,常用来处理实现功能类似数据类型不同的问题
int Add(int left, int right) { return left+right; } double Add(double left, double right) { return left+right; } long Add(long left, long right) { return left+right; } int main() { Add(10, 20); Add(10.0, 20.0); Add(10L, 20L); return 0; }
观察上方的函数,我们会发现他们的函数名相同,参数不同(参数类型,参数顺序等)只有满足上述条件就可以进行函数重载
注意:返回类型的不同的函数并不能进行函数重载!
double Add(double left, double right) { return left+right; } long Add(double left, double right) { return left+right; }
这就是错误的函数重载
2.2名字修饰
这里我们思考个问题,为什么C++支持函数重载而C语言却不支持呢?
在C/C++中,一个程序要运行起来,需要经历以下几个阶段:预处理、编译、汇编、链接
1.实际我们的项目通常是由多个头文件和多个源文件构成,例如在(t.cpp中调用了f.cpp中的函数add)时,在链接前,t.o文件都没有f.o中的add函数地址,
2.所以链接阶段就是为了解决这个问题的,链接器看到t.o调用add,但是没有add的地址,就会到f.o的符号表中找add的地址,然后链接到一起。
3.在链接时,每个编译器的函数名修改规则的不一样,就有可能导致链接的不同,如在gcc的编译器下的函数修饰后名字不变。而g++的函数修饰后变成【_Z+函数长度+函数名+类型首字母】。
4.C++支持函数重载而C却不支持函数重载的原因是:C语言同函数名时无法区分,而C++可以同过函数参数的不同来区别同名的函数!
到此这篇关于C++简明讲解缺省参数与函数重载的用法的文章就介绍到这了,更多相关C++缺省参数与函数重载内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
相关推荐
-
C++深入浅出讲解函数重载
目录 前言 函数重载 1.1 函数重载的概念 1.2 函数重载的意义 1.3 名字修饰(name Mangling) 1.4 extern "C" 前言 自然语言中,一个词可以有多重含义,人们可以通过上下文来判断该词真实的含义,即该词被重载了. 比如:以前有一个笑话,国有两个体育项目大家根本不用看,也不用担心.一个是乒乓球,一个是男足.前者是“谁也赢不了!”,后者是“谁也赢不了!” 函数重载 1.1 函数重载的概念 函数重载: 它是函数的一种特殊情况,C++允许在同一作用域中同一作用域
-
C++ 函数重载背后的原理
目录 函数重载 函数重载的原理 为何C++可以支持重载 程序的编译链接 C语言为何不支持重载 C++为何可以支持函数重载 C++和C语言相互调用 创建静态库 C++调用C extern “C” extern “C” 原理 C语言调用C++ C++ 注意事项 extern "C"修饰的函数和一个函数完全一样 extern "C"修饰的函数和一个函数构成重载 函数重载 我们可能对函数很是熟悉,但是重载又是什么意思呢?我们先来用一个具体的场景来分享. 一天,张三的老板要你
-
C++缺省参数的理解
目录 什么叫缺省参数? 缺省多个参数的情况 1.全缺省 2.半缺省 总结 什么叫缺省参数? 缺省参数是声明或定义函数时为函数的参数指定一个默认值.在调用该函数时,如果没有指定实参则采用该默认值,否则使用指定的实参. 注意:要想省略参数,声明或者定义内必须指定默认值 void TestFunc(int a = 0) { cout<<a<<endl; } int main() { TestFunc(); // 没有传参时,使用参数的默认值 TestFunc(10); // 传参时,使用
-
C++深入分析回顾函数重载
目录 一.函数重载回顾 二.类中的重载 三.重载的意义 四.小结 一.函数重载回顾 函数重载的本质为相互独立的不同函数 C++ 中通过函数名和函数参数确定函数调用 无法直接通过函数名得到重载函数的入口地址 函数重载必然发生在同一个作用域中 二.类中的重载 类中的成员函数可以进行重载 构造函数的重载 普通成员函数的重载 静态成员函数的重载 问题:全局函数,普通成员函数以及静态成员函数之间是否可以构成重载? 注意事项 重载函数的本质为多个不同的函数 函数名和参数列表是唯一的标识 函数重载必须发生在同
-
C++超详细讲解函数重载
目录 1 函数重载的定义 2 构成函数重载的条件 3 编译器调用重载函数的准则 4 函数重载的注意事项 4.1 避开重载带有指定默认值参数的函数 4.2 注意函数重载遇上函数指针 4.3 C++编译器不能以 C 的方式编译重载函数 1 函数重载的定义 函数重载:使用同一个函数名定义不同的函数.从本质上来看,就是互相独立的不同函数,每一个函数类型不同.因此,函数重载是由函数名和参数列表决定的. 注意:函数返回值不能作为函数重载的重要依据! 2 构成函数重载的条件 当满足以下三个条件之一时,便可以构
-
C++命名空间和缺省参数介绍
一.命名空间 为什么引入命名空间 在C++中,变量.函数和类都是大量存在的,这些变量.函数和类的名称将都存在于全局作用域中,可能会导致很多冲突.使用命名空间的目的是对标识符的名称进行本地化,以避免命名冲突或名字污染,namespace关键字的出现就是针对这种问题的. int a = 10; int main(void) { int a = 10; return 0; } 这里一个a是全局变量,一个a是局部变量.可以编译通过
-
C++的缺省参数你了解嘛
目录 一.缺省参数概念 有什么用 二.缺省参数分类 全缺省参数 半缺省参数 总结 一.缺省参数概念 缺省参数是声明或定义函数时为函数的参数指定一个默认值.在调用该函数时,如果没有指定实参则采用该默认值,否则使用指定的实参 #include<iostream> using namespace std; void TestFunc(int a = 0)//参数缺省值 { cout << a << endl; } int main() { TestFunc();//没有指定实
-
C++缺省参数的具体使用
目录 一.缺省参数概念 二.缺省参数分类 全缺省参数 半缺省参数 缺省参数的误区 1.滥用缺省参数,损害代码的结构和可读性. 2.多个缺省参数,可能引入逻辑含混的调用方式 3.重载时可能出现二义性 4.函数调用中的精神分裂症 一.缺省参数概念 缺省参数是声明或定义函数时为函数的参数指定一个默认值.在调用该函数时,如果没有指定实参则采用该默认值,否则使用指定的实参 #include<iostream> using namespace std; void TestFunc(int a = 0)//
-
C++浅析缺省参数的使用
目录 一. 概念 二. 分类 全缺省参数 半缺省参数 一. 概念 缺省参数(有些地方叫默认参数)是声明或定义函数时为函数的参数指定一个默认值.在调用该函数时,如果没有指定实参则采用该默认值,否则使用指定的实参. void TestFunc(int a = 0) { cout << a << endl; } int main() { TestFunc(); //没有传参时,使用参数的默认值 TestFunc(10); //传参时,使用指定的实参 } 二. 分类 全缺省参数 缺省全部参
-
C++简明讲解缺省参数与函数重载的用法
目录 一.缺省参数 1.1缺省参数概念 1.2缺省参数分类 二.函数重载 2.1函数重载概念 2.2名字修饰 一.缺省参数 缺省参数形象来说就是"备胎". 1.1缺省参数概念 缺省参数是声明或定义函数时为函数的参数指定一个默认值.在调用该函数时,如果没有指定实参则采用该默认值,否则使用指定的实参. #include<iostream> void P(int a = 3) { printf("%d", a); } int main() { P();//打印
-
C++深入浅出讲解缺省参数
目录 缺省参数 定义 用法 缺省参数 一般情况下,函数调用时的实参个数应与形参相同,但为了更方便地使用函数,C++也允许定义具有缺省参数的函数,这种函数调用时,实参个数可以与形参不相同. 定义 缺省参数指在定义函数时为形参指定缺省值(默认值).这样的函数在调用时,对于缺省参数,可以给出实参值,也可以不给出参数值.如果给出实参,将实参传递给形参进行调用,如果不给出实参,则按缺省值进行调用. 缺省参数的函数调用:缺省实参并不一定是常量表达式,可以是任意表达式,甚至可以通过函数调用给出.如果缺省实参是
-
C++默认参数与函数重载及注意事项
一.默认参数 在C++中,可以为参数指定默认值.在函数调用时没有指定与形参相对应的实参时, 就自动使用默认参数. 默认参数的语法与使用: (1)在函数声明或定义时,直接对参数赋值.这就是默认参数: (2)在函数调用时,省略部分或全部参数.这时可以用默认参数来代替. 注意: (1)默认参数只可在函数声明中设定一次.只有在没有函数声明时,才可以在函数定义中设定.(#add ,此句意为存在函数声明和定义两部分的时候.验证表明有这个限制,可以随便,但出于规范,在声明中指定) (2)如果一个参数设定了缺省
-
深度探究C++中的函数重载的用法
C++ 允许同一范围内具有相同名称的多个函数的规范.这些函数称为重载函数,"重载"中对其进行了详细介绍.利用重载函数,程序员可以根据参数的类型和数量为函数提供不同的语义. 例如,采用字符串(或 char *)参数的 print 函数执行的任务与采用"双精度"类型的参数的函数执行的任务截然不同.重载允许通用命名并使程序员无需创建名称,例如 print_sz 或 print_d.下表显示了 C++ 使用函数声明的哪些部分来区分同一范围内具有相同名称的函数组. 重载注意事
-
C语言 函数缺省参数详情
目录 一.函数简介 1.函数声明 2.函数定义 3.函数调用 4.函数形参和实参 二.函数缺省参数 1.函数全缺省参数 2.函数半缺省参数 三.注意事项 一.函数简介 1.函数声明 函数声明只是一个空壳,不会有具体的函数实现,而定义要实现函数的实现,例如: int sub(int x,int y); //只需要声明即可,不需要实现这个函数的功能 2.函数定义 函数的定义需要实现这个函数的功能,例如: int sub(int x,int y) ////需要实现这个函数的功能 { return (x
-
c语言中缺省参数的类型总结
1.函数全缺省参数,函数在定义或者声明时,所有的形参都默认值. #include <stdio.h> //x,y为函数的形参,如果函数被调用时,没有设置x和y值,x值默认为100,y值默认为5 int sub(int x=100,int y=5) { return (x-y); } int main(void) { int a=20; int b=10; //变量a.b为sub函数的实参 printf("sub函数计算结果 = %d\n",sub(a, b)); //注意:
-
C++入门基础之命名空间、输入输出和缺省参数
目录 一.命名空间 (1)命名空间的定义 (2)命名空间的使用 (3)全局域 二.输入&&输出 (1) cout (2)cin (3)cin cout自动是识别类型 三.命名空间的展开 (1)使用using namespace 命名空间名称引入 (2)使用using将命名空间中某个成员引入 四.缺省参数 (1)缺省参数概念 (2)缺省参数分类 五.最后 一.命名空间 在C/C++中,变量.函数和后面要学到的类都是大量存在的,这些变量.函数和类的名称将都存 在于全局作用域中,可能会导致很多冲
-
TypeScript中函数重载写法
目录 1. 函数签名 2.函数重载 2.1 重载签名是可调用的 2.1 实现签名必须是通用的 3.方法重载 4. 何时使用函数重载 5.总结 前言: 大多数函数接受一组固定的参数.但有些函数可以接受可变数量的参数,不同类型的参数,甚至可以根据你调用函数的方式返回不同的类型.为了注释这样的函数,TypeScript 提供了函数重载功能. 1. 函数签名 我们先来考虑一个函数,它返回给一个特定的人的问候信息. function greet(person: string): string { retu
-
C++入门(命名空间,缺省参数,函数重载,引用,内联函数,auto,范围for)
一.C++关键字 C++总共有63个关键字,在入门阶段我们只是大致了解一下就可,在后续博客中会逐渐讲解 二.命名空间 相信学过C++的同学,一定都写过下面这个简单的程序 #include<iostream> using namespace std; int main() { cout<<"hello world"<<endl; return 0; } 我们先来看第二行代码,using namespace std , 这行代码是什么意思呢 ? 这里我们
-
Python简明讲解filter函数的用法
目录 一.filter函数的定义 二.filter函数实例 求一个序列中大于零的元素组成的新序列 求序列中非零数组成的新序列 求字典中大于2的键组成的新序列 求100以内既是3的倍数又是奇数的正整数 任何事情都是由量变到质变的过程,学习Python也不例外.只有把一个语言中的常用函数了如指掌了,才能在处理问题的过程中得心应手,快速地找到最优方案. 一.filter函数的定义 filter函数是Python中常用的内置函数,调用无需加载库,直接使用即可.它主要用来根据特定条件过滤迭代器中不符合条件
随机推荐
- Lua编程示例(二):面向对象、metatable对表进行扩展
- Jquery ajax不能解析json对象,报Invalid JSON错误的原因和解决方法
- linux提权用的一个技巧
- PHP 5.2.3 tidy扩展本地溢出漏洞利用代码
- 常用的匹配正则表达式和实例
- MySQL删除表数据的方法
- asp.net 获取客户端浏览器访问的IP地址的实例代码
- 在FireFox/IE下Response中文文件名乱码问题解决方案
- asp.net jquery无刷新分页插件(jquery.pagination.js)
- PHP通用分页类page.php[仿google分页]
- Yii2超好用的日期和时间组件(值得收藏)
- Android开发之图形图像与动画(五)LayoutAnimationController详解
- php/js获取客户端mac地址的实现代码
- js正则表达式惰性匹配和贪婪匹配用法分析
- MYSQL命令行导入导出数据库详解
- JS for循环中i++ 和 ++i的区别介绍
- Shell中实现整数自增的几种方法示例
- python使用opencv读取图片的实例
- Java判断字符串中是否包含中文方法
- DOM中事件处理概览与原理的全面解析