从模板化(静态)成员函数访问受保护的成员
Access protected members from templated (static) member function
好的,所以我在这里采用了一种修改后的CRTP路由,以避免虚拟函数查找。但我就是不能理解它给我的一个错误…
所以我试着翻译:
class A
{
public:
static void foo(A *pA)
{
pA->bar();
}
protected:
virtual void bar()
{
TRACE0(_T("A::barn"));
}
};
class B : public A
{
protected:
virtual void bar()
{
TRACE0(_T("B::barn"));
}
};
如预期的那样工作:
class A
{
public:
template <class T>
static void foo(T *pT)
{
pT->bar();
}
protected:
void bar()
{
TRACE0(_T("A::barn"));
}
};
class B : public A
{
protected:
void bar()
{
TRACE0(_T("B::barn"));
}
};
给出错误:
error C2248: 'B::bar' : cannot access protected member declared in class 'B'
see declaration of 'B::bar'
see declaration of 'B'
see reference to function template instantiation 'void A::foo<B>(T *)'
being compiled with
[
T=B
]
现在我知道了,通过将friend class A;
添加到类B中可以很容易地解决这个问题,但这不是很好。难道没有别的办法吗?
EDIT:示例用法:
B b;
b.foo<B>(&b);
编辑#2:我注意到成员函数foo
是静态的并不重要。
在第一种情况下,bar
是虚拟函数,foo
通过指向A
的指针访问它,从而调用函数指针和指定的Vtable索引作为类A
的布局。这样它就起作用了。
然而,在第二种情况下,A::foo
从它无法访问的不同类显式调用非虚拟函数。B::bar
不是A::bar
的虚拟重载,它是完全不同的无关函数。
因此,恐怕制作friend class A;
是你能得到的最整洁的。
相关文章:
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 将公共但非静态的成员函数与ALGLIB集成
- 使用指向成员的指针将成员函数作为参数传递
- 将重载的成员函数传递给函数模板
- 我不小心调用了一个没有自己类对象的成员函数.但这是怎么回事呢
- 如何在C++中使用非静态成员函数作为回调函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 关联容器的下界复杂性:成员函数与非成员函数
- 在 C++ 中用派生类型重写成员函数
- 链表的泛型函数remove()与成员函数remove)
- 如何将lambda作为模板类的成员函数参数
- constexpr构造函数需要常量成员函数时出现问题
- 将自由函数绑定为类成员函数
- 区分非成员函数和头文件中的成员函数
- 如何从子成员函数修改父公共成员变量
- 保留对其他类的成员函数的引用
- 在运算符重载定义中使用成员函数(const错误)
- 内联如何影响模块接口中的成员函数
- 将成员函数指针作为参数传递给模板方法