How does overloading of const and non-const functions work?(const 和非常量函数的重载是如何工作的?)
问题描述
STL 充满了这样的定义:
iterator begin ();
const_iterator begin () const;
由于返回值不参与重载决议,这里唯一的区别是函数是const.这是重载机制的一部分吗?编译器的解析算法是什么:
As return value does not participate in overloading resolution, the only difference here is the function being const. Is this part of the overloading mechanism? What is the compiler's algorithm for resolving a line like:
vector<int>::const_iterator it = myvector.begin();
推荐答案
在你给出的例子中:
vector<int>::const_iterator it = myvector.begin();
如果 myvector 不是 const,则将调用 begin() 的非 const 版本,您将依赖从迭代器到 const_iterator 的隐式转换.
if myvector isn't const the non-const version of begin() will be called and you will be relying on an implicit conversion from iterator to const_iterator.
这篇关于const 和非常量函数的重载是如何工作的?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:const 和非常量函数的重载是如何工作的?
基础教程推荐
- CString 到 char* 2021-01-01
- GDB 显示调用堆栈上函数地址的当前编译二进制文 2022-09-05
- 为什么派生模板类不能访问基模板类的标识符? 2021-01-01
- 如果我为无符号变量分配负值会发生什么? 2022-01-01
- 为什么 RegOpenKeyEx() 在 Vista 64 位上返回错误代码 2021-01-01
- 我应该对 C++ 中的成员变量和函数参数使用相同的名称吗? 2021-01-01
- 为什么 typeid.name() 使用 GCC 返回奇怪的字符以及如 2022-09-16
- 通过引用传递 C++ 迭代器有什么问题? 2022-01-01
- 非静态 const 成员,不能使用默认赋值运算符 2022-10-09
- 初始化列表*参数*评估顺序 2021-01-01
