我想用简单的 C++ 语法创建一个简单的工厂方法:
void *createObject(const char *str,...)
{
if(!strcmp("X",str))
return new X(...);
}
我想不出这个的语法。我一直在研究模板元编程并使用 mpl::vectors,但我不确定如何传递这种语法。如果可能的话,我想真正避免使用 C va_lists,并寻求像上面那样的简洁语法。
最佳答案
这将是 C++11 上更好的方法:
template< typename ...Args >
std::shared_ptr<void> createObject( std::string const& name, Args&& ...args )
{
if( name == "X" )
{
return try_make_shared< X >( std::forward< Args >( args )... );
}
/* other cases here*/
return nullptr;
}
template< typename T, typename ...Args >
typename std::enable_if<
std::is_constructible< T, Args >::value
, std::shared_ptr< T >
>::type try_make_shared( Args&&... args )
{
return std::make_shared< X >( std::forward< Args >( args )... );
}
template< typename T, typename ...Args >
typename std::enable_if<
!std::is_constructible< T, Args >::value
, std::shared_ptr< T >
>::type try_make_shared( Args&&... args )
{
throw std::invalid_argument( "The type is not constructible from the supplied arguments" );
return nullptr;
}
与您的代码的区别是
它使用可变参数模板函数而不是省略号参数,因此参数的数量和类型在编译时仍然可用(您不会放松类型检查)。此外,您可以使用非 POD 类型调用此函数。
它返回一个
shared_ptr<void>
而不是普通的void*
.这允许您从工厂内部控制一旦对对象的所有引用都消失后应如何清理该对象。用户不需要知道或关心他是否应该调用标准delete
,或者可能是deleteObject
来自您工厂的方法。
更新:对于那些建议 unique_ptr
的人, 你可以阅读 here关于 shared_ptr
的可能性带到 table 上。只返回指向 new
的指针的受限工厂-ly 分配的对象可以而且应该使用 unique_ptr
.
关于C++ createObject() 工厂,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14113741/