制作 boost:::fusion::result_of::as_set<> 的实例不调用其元素的构造函数
making boost::fusion::result_of::as_set<> 's instance doesn't call its elements' constructors
#include <iostream>
#include <boost/mpl/front.hpp>
#include <boost/mpl/pop_front.hpp>
#include <boost/mpl/push_front.hpp>
#include <boost/mpl/push_back.hpp>
#include <boost/mpl/pop_back.hpp>
#include <boost/mpl/fold.hpp>
#include <boost/mpl/transform.hpp>
#include <boost/mpl/vector.hpp>
#include <boost/mpl/set.hpp>
#include <boost/mpl/back_inserter.hpp>
#include <boost/fusion/include/set.hpp>
#include <boost/fusion/include/mpl.hpp>
/**********definition of nodes**************/
struct node_base
{};
struct node_a : public node_base
{
node_a(){std::cout << "node_a::Ctor"<< std::endl;}
};
struct node_b : public node_base
{
node_b(){std::cout << "node_b::Ctor"<< std::endl;}
};
struct node_c : public node_base
{
node_c(){std::cout << "node_c::Ctor"<< std::endl;}
};
struct empty_node {};
/***********definition of table*************/
struct my_table : ::boost::mpl::vector3<
::boost::mpl::vector3<node_a, node_b, node_c>
,::boost::mpl::vector3<node_b, node_c, node_a>
,::boost::mpl::vector3<node_c, node_a, node_b>
> {};
/*************meta-functions**************/
struct make_tag_vector_
{
template<class NODE1, class NODE2>
struct apply
{
typedef typename ::boost::mpl::vector<NODE1>::type type;
};
};
struct fold_table
{
template<class LIST, class VECTOR>
struct apply
{
typedef typename ::boost::mpl::front<VECTOR>::type parent;
typedef typename ::boost::mpl::pop_front<VECTOR>::type children;
typedef typename ::boost::mpl::pop_back<children>::type tmp;
typedef typename ::boost::mpl::push_front<tmp, empty_node>::type right_shift_children;
typedef typename ::boost::mpl::transform<
children
, right_shift_children
, make_tag_vector_
, ::boost::mpl::back_inserter<LIST>
>::type type;
};
};
template<class TABLE>
struct create_table
{
typedef typename ::boost::mpl::fold<
TABLE
, ::boost::mpl::vector0<>
, fold_table
>::type type;
};
/**********process table**************/
typedef create_table<my_table>::type table_type;
typedef ::boost::mpl::reverse_fold<
table_type
, ::boost::mpl::set0<>
, ::boost::mpl::insert<
::boost::mpl::placeholders::_1
, ::boost::mpl::front<::boost::mpl::placeholders::_2>
>
>::type node_set_type;
/**********result of node_set_type is :**************/
// struct node_c
// struct node_a
// struct node_b
/**********convert to fusion set type**************/
typedef ::boost::fusion::result_of::as_set<node_set_type> fusion_set_type;
/**********create fusion set instance**************/
fusion_set_type instance;
这段代码可以编译。我的问题是,当我们创建"fusion_set_type"的实例时,该融合集中的所有类型的构造函数都应该被调用。然而,这个"fusion_set_type"不会调用任何包含它的类型的构造函数。也许在嵌套的折叠/转换操作中有一些不正确的东西。"node_set_type"的结果是"struct node_c, struct node_a, struct node_b",当我使用mpl::for_each加上一个函数对象来循环"node_set_type"时,所有节点的构造函数都成功地被调用。谢谢!
可能是打字错误?我在ideone上测试时调用了构造函数将::type
添加如下:
/**********create fusion set instance**************/
fusion_set_type::type instance;
相关文章:
- OpenGL - 在抛出"__gnu_cxx::recursive_init_error"实例后终止调用?
- 从基类实例调用派生类方法而不进行强制转换
- 如何在C++从父实例调用子函数
- 为 std::shared_ptr 实例调用 Operator()
- 跨类的多个实例调用函数一次
- 如何从派生类实例调用父类重载函数
- 如何在C++中跨实例调用方法
- 防止同一类的实例调用公共功能(C )
- 使用Objective C类实例调用C函数
- 从结构实例调用变量语法问题C++
- 从基类实例调用派生类方法
- C++从基类实例调用派生函数
- 是否可以从不存在的实例调用方法?
- 如何使用派生类实例调用基类重载的func,
- 为singleton实例调用函数创建一个别名
- 用结构体的所有实例调用函数
- 从继承的类实例调用静态成员
- 当我从类实例调用方法时,我的C程序崩溃了,下面是代码
- 当尝试使用类的实例调用方法时,调试断言错误
- C++:从派生实例调用 base 中的纯虚拟方法重载