首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >参数包参数消耗

参数包参数消耗
EN

Stack Overflow用户
提问于 2012-09-16 10:35:57
回答 2查看 1.8K关注 0票数 5

可以获得参数包的第一个元素,如

代码语言:javascript
复制
template <typename... Elements>
struct type_list
{
};

template <typename TypeList>
struct type_list_first_element
{
};

template <typename FirstElement, typename... OtherElements>
struct type_list_first_element<type_list<FirstElement, OtherElements...>>
{
    typedef FirstElement type;
};

int main()
{
   typedef type_list<int, float, char> list;
   typedef type_list_first_element<list>::type element;
   return 0;
}

但不可能获得类似于的最后一个元素

代码语言:javascript
复制
template <typename... Elements>
struct type_list
{
};

template <typename TypeList>
struct type_list_last_element
{
};

template <typename LastElement, typename... OtherElements>
struct type_list_last_element<type_list<OtherElements..., LastElement>>
{
    typedef LastElement type;
};

int main()
{
   typedef type_list<int, float, char> list;
   typedef type_list_last_element<list>::type element;
   return 0;
}

gcc 4.7.1抱怨:

错误:'struct type_list_last_element>‘中的' type’没有命名类型

标准中的哪些芦笋描述了这种行为?

在我看来,模板参数包在某种意义上是贪婪的,因为它们消耗了所有匹配的参数,在本例中,这意味着OtherElements消耗了所有三个参数(intfloatchar),然后LastElement就什么都没有了,所以编译失败了。我的假设正确吗?

编辑:

为了澄清:我不是问如何从参数包中提取最后一个元素,我知道如何这样做。我真正想要的是把包从后面拿出来,而不是前面,这样的话,每个元素都会一直循环到后面,这将是无效的。最明智的选择显然是提前逆转顺序。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-09-19 15:36:28

相关条款是14.5.5:8结尾的项目:

14.5.5类模板部分专门化temp.class.spec 8.在类模板部分专门化的参数列表中,适用以下限制:

  • 参数不应包含未展开的参数包。如果参数是pack展开(14.5.3),则它将是模板参数列表中的最后一个参数。
票数 4
EN

Stack Overflow用户

发布于 2012-09-18 19:38:43

观察:

  1. 如果只有<first,...>不是空的,那么<...>的最后一个元素与<...>的最后一个元素是相同的。
  2. 一个元素列表<elem>的最后一个元素是elem

因此,您必须使用尾模板递归地执行此操作:

递归:

代码语言:javascript
复制
template <typename TypeList>
struct type_list_last_element;

template <typename FirstElement, typename... OtherElements>
struct type_list_last_element<type_list<FirstElement, OtherElements...>>
{
    typedef typename type_list_last_element<type_list<OtherElements...>>::type type;
};

尾巴:

代码语言:javascript
复制
template <typename LastElement>
struct type_list_last_element<type_list<LastElement>>
{
    typedef LastElement type;
};

更新和用法:

代码语言:javascript
复制
int main()
{
   typedef type_list<int, float, char> list;
   typedef type_list_last_element<list>::type last;
   return 0;
}

端更新

请参阅意为

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12446229

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档