以下程序无法编译:

template <unsigned int dim, unsigned int N, bool P, bool C, class... ParametersType>
void test(ParametersType&&... par)
{
}

int main()
{
    test<2, 3, true, false>(2, 1, {8, 8});
}

看到它live on Coliru

错误讯息
g++ -std=c++17 -O1 -Wall -pedantic -pthread main.cpp && ./a.out

main.cpp: In function 'int main()':

main.cpp:8:41: error: too many arguments to function 'void test(ParametersType&& ...)
 [with unsigned int dim = 2; unsigned int N = 3; bool P = true; bool C = false; ParametersType = {}]'

    8 |     test<2, 3, true, false>(2, 1, {8, 8});

      |                                         ^

main.cpp:2:6: note: declared here

    2 | void test(ParametersType&&... par)

      |      ^~~~

表示参数包ParametersType...推导为空,而我希望根据传递给test的参数类型推导它。

问题出在传递给{8, 8}test参数中。
显式传递std::array到函数可以解决此问题:
#include <array>

template <unsigned int dim, unsigned int N, bool P, bool C, class... ParametersType>
void test(ParametersType&&... par)
{
}

int main()
{
    test<2, 3, true, false>(2, 1, std::array<int, 2>{8, 8});
}

看到它live on Coliru

为什么在第一个示例中,编译器显然错误地推导出了Pack?

如果编译器无法将{8, 8}推导为std::array,则可能会出现“无法推论”错误。为什么相反,编译器将包推导出为空?

最佳答案

模板错误很难纠正。这只是实现的质量。 lang实例

main.cpp:2:6: note: candidate template ignored: substitution failure
[with dim = 2, N = 3, P = true, C = false]: deduced incomplete pack <int, int, (no value)>
for template parameter 'ParametersType'

这更容易理解。是的,除非使用auto {stuff} has no type

关于c++ - 模板参数包的错误推导,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/61326657/

10-11 18:28