我想拥有一个为调用类分配shared_ptrs的公共基类/助手类,但我在使它在派生类中工作时出现问题。在基类中有一个方法能够为子类分配
#include <memory>
template<typename T>
struct SPAlloc {
virtual ~SPAlloc() {}
template<typename ...Args>
static std::shared_ptr<T>
Alloc(Args&&... params) {
return std::make_shared<T>(std::forward<Args>(params)...);
}
template<class U, typename ...Args>
static std::shared_ptr<U>
Alloc(Args&&... params) {
return std::make_shared<U>(std::forward<Args>(params)...);
}
};
class Base : public SPAlloc<Base> {
public:
virtual ~Base() {};
};
class Child : public Base {
public:
virtual ~Child() {};
};
typedef std::shared_ptr<Base> pBase;
typedef std::shared_ptr<Child> pChild;
int main() {
pBase base = Base::Alloc();
pChild child = Child::Alloc();
}
我明白class Base : public SPAlloc<Base>
意味着T
模板将是Base
,这就是为什么我创建的第二个的Alloc。第二个分配需要被调用,如Child::Alloc<Child>()
。
有没有办法写这个Alloc
,这样编译器就可以推导出我正在调用Alloc的类?
我也这么想。我希望能为所有的类提供一个包装器,并且让编译器/做我想要的/。我想包装std :: make_shared的原因是,如果我想改变将来分配类的方式(尽管我想我可以使用allocate_shared)。无论如何,现在,我将只有一个独立的函数来封装make_shared – Naddiseo 2013-03-25 03:58:22