Fah*_*tha 10 c++ template-templates variadic-templates c++11
我在Debian上使用gcc 4.4.请考虑以下代码.
#include <map>
#include <string>
using std::map;
using std::string;
// Args lets the user specify additional explicit template arguments
template <typename T,
template <typename T, typename... Args> class C,
typename... Args>
C<T, Args...> foo()
{
C<T, Args...> x;
return x;
}
int main(void)
{
map<string, int> a = foo<string, map, int>();
}
Run Code Online (Sandbox Code Playgroud)
所以,这里的想法是T匹配string,C匹配map和模板参数包Args匹配int.我可能有一些错误的语法,如果是这样,请更正.特别是,如果希望第一个模板参数class C匹配T而其余模板参数匹配模板参数包Args,template <typename T, typename... Args> class C那么语法是否正确?
这给出了错误
In function 'int main()':
post.cc:18: error: no matching function for call to 'foo()'
Run Code Online (Sandbox Code Playgroud)
这看起来类似于Variadic模板模板和完美转发的问题.这个问题表明这是一个gcc bug,但也许我错误地认为这些问题是关于同一件事.
请温柔.我对可变参数模板的了解不到12小时; 我只是想重写一些旧的C++代码来减少重复.自从我做了任何C++以来,它已经有一段时间了.如果有解决方法,请告诉我.谢谢.
编辑:在的意见提出的解决方法可变参数模板的模板和完美转发由伊势紫藤工作对我来说,这表明这是相同的错误.当然,我现在(a)想知道这种解决方法是多么脆弱,(b)为什么它有效,以及是什么促使伊思思考它.虽然我猜只有伊势才能回答最后一点.:-)
正如编辑中所讨论的,我的问题似乎与链接的问题、可变模板模板和完美转发存在相同的错误。特别是,链接中给出的解决方法也适用于我的情况。修改后的工作代码如下:
#include <map>
#include <string>
using std::map;
using std::string;
template <typename T,
template <typename T, typename... Args> class C,
typename... Args>
struct X
{
typedef C<T, Args...> type;
};
template <typename T,
template <typename T, typename... Args> class C,
typename... Args>
typename X<T, C, Args...>::type foo()
{
C<T, Args...> x;
return x;
}
int main(void)
{
map<string, int> a = foo<string, map, int>();
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6434 次 |
| 最近记录: |