Using boost mpl pop_front
Using boost mpl pop_front
Having:
#include <typeinfo>
#include <boost/mpl/vector.hpp>
#include <boost/mpl/pop_front.hpp>
int main()
{
typedef boost::mpl::vector<char,short,int,long,long long> v;
typedef typename pop_front<v>::type poped;
}
问题是poped不等于boost::mpl::vector
如何使它返回没有第一个元素的向量?
也许mpl::equal可以帮助你澄清为什么这并不重要。
确保它们相等,但不一定相同。
BOOST_MPL_ASSERT((mpl::equal<
typename pop_front<v>::type,
mpl::vector<short,int,long,long long>
>));
这就是你真正需要的;-)
我不确定这是否可能使用MPL功能。即使您尝试使用copy
和back_inserter
将poped
复制到vector
中,您将再次获得一个不是真正的vector
的类型。这是经过设计的:就像Boost一样。融合、MPL的算法和元函数返回原始序列的视图,提供延迟求值。这些视图可以像原始序列一样使用,所以您不应该担心它们的实际类型是什么,只需像使用vector
(或list
s,或map
s等)一样使用它们。
相关文章:
- muQueue.front() 给出了 const 实例,即使我没有将其标记为 const
- 在c++队列中使用pop和visit实现线程安全
- 如何实现 Front() 方法以返回模板化双向链表C++的第一个元素?
- C++ queue.front();为什么不从第一个元素开始呢?
- C++:如何正确地将 deque::front() 返回的变量从函数中传递出去?
- C++ push() 和 pop() 方法使用指针的动态 LinkedList 的问题
- C++ 带模板的链表 - 如何创建 pop()?
- std::stack的奇怪行为,pop()返回相同的值
- 为什么以下 POP 功能无法在主机或设备 (CUDA) 上运行?
- C++ 中类成员的堆栈的 pop() 函数
- 没有相应 POP 的编译指示包(推送)会导致堆栈粉碎
- Boost::msm 如何使用非默认构造函数初始化state_machine_def和 msm::front::sta
- 递归推动POP POSTFIX计算器无法正确执行操作,只需将最后一个数字作为结果
- 关于反序列化程序 pop 函数的模板化专用化的歧义
- 列表大小为 1,但 front() 和 back() 不相等
- E0020 标识符"pop"未定义
- 无效地将 void 表达式与队列和 .pop() 一起使用
- 如何存储队列返回的值::front?
- 当您通过Qt小部件打开文件时,是否可以'pop-up'文件?
- 模板堆栈类的复制构造函数中的 pop() 和 push() 不起作用