用c++中的纯虚拟方法抽象模板类

Abstract template class with pure virtual method in c++

本文关键字:抽象 方法 虚拟 c++      更新时间:2023-10-16

public/Interface.h

#pragma once
template <typename T>
class BaseInterface {
public:
virtual void foo() = 0;
};

private/Base.h

#pragma once
#include "../public/Interface.h"
template <typename T>
class Base : public BaseInterface<T> {
public:
virtual void foo() override;
};
template <typename T>
inline void Base<T>::foo() {
}

main.cpp

#include <iostream>
#include <memory>
#include "public/Interface.h"
int main() {
auto base = std::make_shared< BaseInterface<std::string> >();
base->foo();
return 0;
}    

获取此错误:

/usr/include/c++/5/ext/new_allocator.h:120:4: error: invalid new-expression of abstract class type ‘BaseInterface<std::__cxx11::basic_string<char> >’
{ ::new((void *)__p) _Up(std::forward<_Args>(__args)...); }
AbstractPureVirtual/public/Interface.h:4:7: note:   because the following    virtual functions are pure within ‘BaseInterface<std::__cxx11::basic_string<char> >’:
class BaseInterface {
AbstractPureVirtual/public/Interface.h:6:17: note:  void BaseInterface<T>::foo() [with T = std::__cxx11::basic_string<char>]
virtual void foo() = 0;

虽然我已经重写了派生类中的纯虚拟方法,并且它似乎是一个模板类,但我还是收到了这个错误。如果我需要做类似的事情,我应该如何实现它?

make_shared创建一个与您指定的类完全相同的对象。它无法知道它的派生类,所以make_shared< BaseInterface<std::string> >()本质上调用new BaseInterface<std::string>,并且不允许创建抽象类的对象。这与模板无关;如果用普通类替换它们,错误仍然存在。

auto base = std::make_shared< BaseInterface<std::string> >();

您尝试在此处创建BaseInterface<std::string>类型的具体对象。我怀疑你想要:

auto base = std::make_shared< Base<std::string> >();

或者

std::shared_ptr< BaseInterface<std::string> > base = std::make_shared< Base<std::string> >();