CRTP对派生中受保护的CTOR的访问
CRTP access to protected CTOR in derived
我在stackoverflow上看了看,没有发现我的确切问题,所以我发布了它。我是用cxx03构建的,所以cxx11+功能是不允许的。
我有以下简化说明:
template<typename T>
struct unprotect : public T {
static T *create(void) {
return new T;
}
};
template<class T>
struct Base
{
private:
public:
static T * Create(void) {
return unprotect<T>::create();
}
static void Destroy(T *p) {
delete p;
}
};
struct Derived : public Base<Derived>
{
protected:
Derived(void){}
};
int main(int argc,const char** argv)
{
Derived * d = Derived::Create();
Derived::Destroy(d);
return( 0 );
}
这会在g++v4.8中产生以下错误:
24)~/workspace/tricks $ g++ src/tricks.cpp
src/tricks.cpp: In instantiation of 'static T* unprotect<T>::create() [with T = Derived]':
src/tricks.cpp:14:37: required from 'static T* Base<T>::Create() [with T = Derived]':
src/tricks.cpp:29:28: required from here
src/tricks.cpp:24:5: error: 'Derived::Derived()' is protected
Derived(void){}
^
src/tricks.cpp:4:20: error: within this context
return new T;
我本以为,由于unprotect继承自T,unprotect::create()将可以访问派生类的protected构造函数。
这就是问题所在:使用CRTP,我希望Base能够添加一个create()方法,该方法可以访问Derived的CTOR,但不要求Derived声明与Base的友谊。
一个糟糕的方法是做以下事情:
template<typename T>
struct unprotect : public T {
static T *create(void) {
return new unprotect;
}
};
这将克服最初的问题,但它会阻碍(纯粹的)虚拟技术,很可能会引起一两个令人讨厌的惊喜。
有没有一种方法可以使最初的实施发挥作用?同样,我不想将基本友谊添加到派生。
不幸的是,在C++中,你无法完成你想要做的事情。你要么必须在Derived
中编写公共创建函数,要么允许它的构造函数是公共的(你想用受保护的构造函数解决什么问题?)。
所有受保护的意思是派生类的this
指针可以用于访问父类的受保护成员。它不会授予子类对任意父类实例的任意受保护成员的任意访问权限(包括当实例刚刚由new
创建时)。
相关文章:
- 通过方法访问结构
- 使用不带参数的函数访问结构元素
- 如果我只是不访问queue_front节点的子节点,而是将它们推到队列中呢?还是BFS吗
- 用于访问容器<T>数据成员的正确 API
- 访问者访问变体并返回不同类型时出错
- 尝试通过多个向量访问变量时,向量下标超出范围
- 无法访问嵌套类.类的使用无效
- 写入位置0x0000000C时发生访问冲突
- 我们可以访问一个不存在的联盟的成员吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 我的简单if-else语句是如何无法访问的代码
- 从C++dll访问C#中的一行主要参数
- 概念TS检查忽略私有访问修饰符
- 访问被拒绝后,c++中的故障保护代码
- std::is_base_of表示ctor编译错误
- 在c++中访问int到类对象的映射时出错
- 带有抛入 ctor 的对象的单例 - 再次访问?
- 自 C++17 以来,复制 elision 不需要存在和访问复制或移动 CTOR
- CRTP对派生中受保护的CTOR的访问
- 将std::vector v传递给类的ctor,该类需要在相应实例的整个生命周期内访问v