У меня есть шаблон класса со статической функцией-оболочкой, которая возвращает общий_ptr.
class bar {};
template < class T >
class foo : public bar
{
public:
T variable ;
foo ( T t ) : variable ( t ) {}
virtual ~foo(){}
template < typename T > using foo_shared_ptr = std::shared_ptr < foo < T > > ;
template < typename T, typename... Args >
foo_shared_ptr < T >
static foo_make_shared_ptr ( Args&&... args )
{
return std::make_shared < foo < T > > ( std::forward < Args > ( args ) ... ) ;
}
} ;
template < typename T > using foo_alias = foo < T >::make_shared_ptr < T > ;
Это отлично работает, я могу создать общий_ptr из объекта foo следующим образом:
#inclulde "foo.h"
#inclulde
int main(){
foo < std::string > test ( "hello world" ) ;
foo < std::string >::foo_make_shared_ptr < std::string > ( test ) ;
}
Однако я изо всех сил пытаюсь написать псевдоним, чтобы сделать вызов foo_make_shared_ptr менее громоздким. Я экспериментировал с чем-то вроде этого:
template < typename T > using foo_alias = foo < T >::make_shared_ptr
// then called like
foo_alias < std::string > ( test ) ;
Но мне не удалось заставить это работать. Возможно ли это сделать или есть лучший подход?
Я также пробовал что-то подобное, что приводило к внутренней ошибке компилятора:
template < typename T > using foo_alias = typename foo < T >::template make_shared_ptr < T > ;
Подробнее здесь: https://stackoverflow.com/questions/798 ... on-wrapper