【问题标题】:C++ template constructor default argumentsC++ 模板构造函数默认参数
【发布时间】:2016-03-01 21:06:56
【问题描述】:

以一种非常简单的方式。我们有以下代码:

struct templateTest{
    struct {}m_none;
    template <typename T1, typename T2, typename T3, typename T4>
    templateTest(T1 arg1, T2 arg2=m_none, T3 arg3=m_none, T4 arg4=m_none){

    }
};

struct nonTemplate{
    nonTemplate(int arg1, int arg2=2, int arg3=3){}
};

int main()
{
    nonTemplate(5);
    nonTemplate(5,10);

    templateTest test2(5,10);
    templateTest test1(5);


    return 0;
}

我想要的是模板类中的默认构造函数参数。

默认参数在nonTemplate 类中工作得很好,但在templateTest 类型中却不是这样。我遇到的错误如下:

C2660: 'templateTest::templateTest' : 函数不接受 2 个参数

用于使用 2 个参数调用的构造函数

对于使用一个参数调用的构造函数,编译器想要调用 copyConstructor 并且输出如下:

C2664: 'templateTest::templateTest(const templateTest &)' : 无法将参数 1 从 'int' 转换为 'const templateTest &'

有什么方法可以在旧的 C++ 编译器上实现我想要的,比如 msvc 2011?

【问题讨论】:

标签: c++ templates default-value


【解决方案1】:
struct none_t {};
template <class T1, class T2=none_t, class T3=none_t, class T4=none_t>
templateTest(T1 arg1, T2 arg2=none_t{}, T3 arg3=none_t{}, T4 arg4=none_t{}){

}

您不能从默认参数中推断出模板类型参数。本质上,模板类型参数是在默认参数被替换之前推导出来的。

live example.

【讨论】:

  • 是的,事实上我知道它可以工作,但它不能在 msvc 2012 上编译,因为我不能在类成员上使用默认模板类型。然后呢?
  • @DawidPi 重载。
  • @DawidPi 创建了 4 个重载,具有几乎完全复制的主体和初始化列表,每个都采用 1 2 3 和 4 个参数?获取新的编译器?
  • 事实上我现在就是这样做的 :) 但是我有 9 个参数函数,所以你可以想象代码变得多么丑陋。当然,为整个公司获得新的编译器对我来说是不可能的 :) 但仍然感谢 :)
  • @DawidPi Boost 有用于模拟可变参数的宏。您还可以编写一个函数对象(不是模板函数,因为您不能传递它们,也不是函数,因为它们不能表示超过 1 个重载)并创建一个使其可变的适配器(编写上述 9+ 重载,如果您发现自己不止一次这样做,则根据传入的参数将更多/更少的none_ts 分派给函数对象。
猜你喜欢
  • 2011-03-27
  • 1970-01-01
  • 2012-02-15
  • 2014-07-09
  • 1970-01-01
  • 2014-05-18
  • 1970-01-01
  • 2011-07-15
  • 1970-01-01
相关资源
最近更新 更多