博客
关于我
为什么C++支持函数重载,而C语言不支持函数重载呢?(有图易懂)
阅读量:305 次
发布时间:2019-03-01

本文共 770 字,大约阅读时间需要 2 分钟。

C++函数重载与C语言的区别

函数重载是C++特有的一个功能,它允许在同一作用域中定义多个具有相同名称但参数列表不同的函数。这与C语言的行为有明显区别,理解这一点对于掌握C++编程至关重要。

为什么C++支持函数重载,而C语言不支持?

C++通过对符号的复杂处理实现了函数重载。函数在C++中的符号不仅仅由名称决定,还包括参数的类型、数量以及顺序。具体来说,C++编译器将函数符号转换为特定的格式,例如?函数名@@YA...@Z。其中,Y表示函数返回类型,后面的部分表示参数类型和顺序。这种机制使得即使函数名相同,只要参数不同,编译器也能区别对待。

C语言的函数符号机制

C语言的函数符号机制相对简单,编译器仅根据函数名进行区分。在C语言中,函数名是唯一的标识符,参数的类型和数量不会影响函数的标识。因此,如果两个函数具有相同的名称但不同的参数,C语言编译器会将它们视为同一个函数,从而导致重定义错误。

C++中的函数符号

在C++中,函数符号的结构更为复杂。编译器会将函数名与参数信息结合起来生成唯一的符号。例如:

  • int add(int, int)
  • int add(char, int)

这两个函数虽然名称相同,但参数类型不同,编译器会将它们视为两个不同的函数。

GCC编译示例

在实际编译过程中,我们可以看到C++编译器如何处理函数重载。例如,以下代码:

add(int a, int b);add(char a, int b);

在编译时,GCC会将这两个函数的符号分别转换为addIiaddHi,从而避免重定义错误。这样,两个函数可以共存且互不影响。

总结

C语言的函数符号仅由名称决定,这限制了函数的重载能力。而C++通过对参数信息的处理,实现了更复杂的符号机制,从而支持了函数重载。理解这一点对于深入掌握C++编程非常重要。

转载地址:http://xwao.baihongyu.com/

你可能感兴趣的文章
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>