C++ createObject() 工厂

标签 c++ templates boost-mpl

我想用简单的 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/

相关文章:

C++互斥锁定线程优先级

c++ - 从 Push_back 取回数据

c++ - 具有类型特征的通用 lambda

c++ - boost mpl fold 占位符表达式无法编译

c++ - 使用 Visitor 对 Boost Variant 中的类型进行分类无法编译

c++ - 递归逃出迷宫

c++ - getNth() 堆栈中的项目

c++ - 为什么模板函数的Template在Visual C++中无效

c++ - 模板化配置值类和全局列表

c++ - 获取所有基类 [元编程]