请考虑以下示例:
#include <iostream> struct foo { void fun() const { std::cout << "foo::fun()" << std::endl; } }; auto main() -> int { foo f; f.fun(); f.foo::fun(); return 0; }
>如上例所示,成员函数foo :: fun()以两种不同的方式引发.
>在第二次调用(即f.foo :: try())中,成员类foo :: fun()的范围被明确消除歧义/解析.
问题:
>两个电话之间的区别是什么(即f.fun()和f.foo::fun())?
>调用成员函数或可公开访问的成员变量是否有任何优势,明确消除其范围与经典方式调用它的范围?
>通过明确消除其范围歧义,调用成员函数或可公开访问的成员变量是否存在任何缺陷?
解决方法
一个区别是,如果fun()是一个虚函数,那么第二种方式调用它会抑制虚拟调度.
struct foo { void virtual fun() const { std::cout << "foo::fun()" << std::endl; } }; struct bar : foo { void fun() const override { std::cout << "bar::fun()" << std::endl; } }; auto main() -> int { bar b; foo *f = &b; f->fun(); f->foo::fun(); }
输出:
bar::fun() foo::fun()
同样,如果您反而从基类隐藏了一个函数,它允许您访问基类版本.
struct foo { void fun() const { std::cout << "foo::fun()" << std::endl; } }; struct bar : foo { void fun(int) const { std::cout << "bar::fun()" << std::endl; } }; auto main() -> int { bar b; b.fun(10); b.foo::fun(); }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。