c – 明确解决类成员的范围

c – 明确解决类成员的范围,第1张

概述请考虑以下示例: #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;} DEMO >如上例所示,成员函数 请考虑以下示例:

#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;}

DEMO

>如上例所示,成员函数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()

Live demo

同样,如果您反而从基类隐藏了一个函数,它允许您访问基类版本.

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();}
总结

以上是内存溢出为你收集整理的c – 明确解决类成员的范围全部内容,希望文章能够帮你解决c – 明确解决类成员的范围所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1218068.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存