请教一个有关const&的问题

rt,lz有一个有关const ref的问题,查了资料没找到合适的答案,讨论区的各位大佬走过路过麻烦解答一下~
以下是代码截图:

上图为头文件verify.h的代码,

上图为cpp文件verify.cpp的代码。
如图所示,我在verify.h文件中声明了fun4和fun5两个函数,在verify.cpp文件中实现了fun4和fun5两个函数,和.h文件中的声明不同的是,我在.cpp文件中的实现,给每个参数都加上了const。

执行上图所示的main函数代码,fun4会编译出错,报错undefined ref,也就是说,编译器认为cpp文件中fun4的实现是头文件中fun4函数的重载;而fun5则能成功执行。
lz的疑惑在于,为什么在实现上在&对象参数上加上一个const就会被编译器认为是不同的函数。const &的const和一般的const相比,有什么特殊的作用吗?

#C/C++#
全部评论
const按照c++primer的说法分为底层const和顶层const,你那样的引用或者指针都是底层的,也就是说所引用或者所指向的那块地方不能改变,底层const是可以重载的,顶层的就不行,比如你用const int a做形参和用int a做是一样的,顶层const也就是当前值不能变,作为函数参数或者返回值的时候没有一点作用,甚至你传一个顶层的const的实参都可以转换成普通的变量
点赞 回复 分享
发布于 2018-05-05 22:15
参考《C++ Primer》第五版6.4函数重载 一个拥有顶层const的形参无法和另一个没有顶层const的形参区分开 另一方面,如果形参是某种类型的指针或引用,则通过区分其指向的是常量对象还是非常量对象可以实现函数重载,此时的const是底层的 void f(int); void f(const int); // 重复声明 void g(int&); void g(int& const); // 重复声明 void h(int&); void h(const int&); // 重载 我的理解是,因为T和const T可以互相进行隐式类型转换,但是const T&则无法隐式转换成T&,所以你传递一个const对象时,不能匹配到接收非const引用的函数,这样编译器在处理const对象实参时,可以选择void h(const int&)这种形式。
点赞 回复 分享
发布于 2018-05-05 22:24
void foo(int) void foo(const int) 上面这个两个函数在调用者看来是一样的,所以不被认为是重载 但是 void foo(int &) void foo(const int &) 这两者作用完全不同
点赞 回复 分享
发布于 2018-05-05 22:20
const引用具有底层const,可以重载,所以fun4是有两个版本的,而const常量是顶层const,重载是会忽略顶层const,所以只有一个版本的fun5
点赞 回复 分享
发布于 2018-05-05 23:35

相关推荐

我已成为0offer的糕手:别惯着,胆子都是练出来的,这里认怂了,那以后被裁应届被拖工资还敢抗争?
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务