const 和非常量函数的重载是如何工作的? [英] How does overloading of const and non-const functions work?

查看:21
本文介绍了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 和非常量函数的重载是如何工作的?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆