C ++模板包扣除 - 在这个例子中我做错了什么?

时间:2015-10-14 15:23:42

标签: c++ templates variadic-templates variadic type-deduction

这编译并正常工作:

template<typename T, typename ... Args>
void func()
{
    std::cout << __PRETTY_FUNCTION__ << std::endl;
    func<Args...>();
}

int main()
{
    func<int, char, float>();
    return 0;
}

...这也可编译并正常工作:

struct Object {};   // Some dummy object

template<typename T, typename ... Args>
void func(Object *a)
{
    std::cout << __PRETTY_FUNCTION__ << std::endl;
    func<Args...>(a);
}

int main()
{
    Object *a = new Object;
    func<int, char, float>(a);
    return 0;
}

...但这不会编译,因为它无法解析T:

struct Object {};   // Some dummy object

template<typename T, typename ... Args>
void func(Object *a, Object *b)
{
    std::cout << __PRETTY_FUNCTION__ << std::endl;
    func<Args...>(a, b);
}

int main()
{
    Object *a = new Object;
    Object *b = new Object;
    func<int, char, float>(a, b);
    return 0;
}

我在这里做错了什么?很抱歉无法使用Ideone,因此无法工作。

1 个答案:

答案 0 :(得分:1)

正如@NathanOliver所指出的,您的代码既不使用clang也不使用gcc进行编译。

以下函数实例化:

func<int, char, float>()
func<char, float>()
func<float>()

现在,参数包为空,编译器尝试实例化func<>,这导致无法推断出模板参数T的错误。

为了正确结束递归,您可以使用this SO question的答案之一,例如:

#include <iostream>

template <typename Last>
void func()
{
    std::cout << __PRETTY_FUNCTION__ << std::endl;
}

template<typename First, typename Second, typename ... Args>
void func()
{
    std::cout << __PRETTY_FUNCTION__ << std::endl;
    func<Second, Args...>();
}

int main()
{
    func<int, char, float>();
    return 0;
}

live example

<强>输出

void func() [First = int, Second = char, Args = <float>]
void func() [First = char, Second = float, Args = <>]
void func() [Last = float]