4

我有这样的结构:

struct E1
{
    typedef boost::tuple<  
     boost::optional< N::type_A >, // N - namespace
     boost::optional< N::type_B >,
     ...................
     boost::optional< N::type_X > //arbitrary number of, maximal is 7
     > data_type;


   // for access by name 
   boost::optional<N::type_A> const&  type_A() const { return boost::get<0>(data); }
   boost::optional<N::type_B> const&  type_B() const { return boost::get<1>(data); }
   .....................................
   boost::optional<N::type_X> const&  type_X() const { return boost::get<2>(data); }

   data_type data;
};

问:如何使用 BOOST 预处理器创建这种结构?对我来说,只有 type_A、type_B、...、type_X 类型的名称。

它需要我,因为我必须创建很多这样的结构,只更改 type_A、type_B、... 类型。

在一般情况下,我可以使用 boost 预处理器数组或集合吗?

4

1 回答 1

7

你可以这样做:

#define TYPES (type_A)(type_B)(type_X)


#define GENERATE_TUPLE(maR, maNamespace, maIndex, maType) \
  BOOST_PP_COMMA_IF(maIndex) boost::optional<maNamespace :: maType>


#define GENERATE_GETTER(maR, maNamespace, maIndex, maType) \
  boost::optional<maNamespace :: maType> const& maType () const { return boost::get<maIndex>(data); }


struct E1
{
  typedef boost::tuple<
    BOOST_PP_SEQ_FOR_EACH_I(GENERATE_TUPLE, N, TYPES)
  > data_type;

  BOOST_PP_SEQ_FOR_EACH_I(GENERATE_GETTER, N, TYPES)

  data_type data;
};

N变量对应于maNamespace参数。您当然可以以任何其他方式使用此参数(它只是逐字传递),例如硬编码N到宏中(并在参数中传递一个虚拟变量),或者甚至编码其中的标识符data等。

于 2013-08-26T10:16:31.493 回答