考虑到我有A和A类课程。 B这样
class A
{
public:
void Fun();
};
class B : public A
{
....
};
作为A类的设计者,我是否可以通过隐藏非虚函数Fun()来阻止(从某种错误中获得某种错误)来强制执行派生类B和其他类?
答案 0 :(得分:3)
如果您希望以某种方式始终可以访问非virtual
成员函数,那么只需将其包装在名称空间范围的自由函数中:
namespace revealed {
void foo( A& o ) { o.foo(); }
}
现在B级的客户总是可以
void bar()
{
B o;
revealed::foo( o );
}
但是,无论B级引入多少隐藏重载,客户端也可以执行
void bar2()
{
B o;
A& ah = o;
ah.foo();
}
他们可以做到
void bar3()
{
B o;
o.A::foo();
}
所以所获得的只是一种易于理解的符号和意图沟通。
即,正如评论所说的那样,远非不可能,默认情况下你的可用性就是......