Modern C++ Design 笔记 第三章 3. TypeList

本文介绍了Modern C++ Design中TypeList的概念,通过递归展示了其强大的功能,包括创建任意长度的TypeList,计算TypeList的长度,获取指定索引的类型,以及删除和替换元素等操作。TypeList的实现利用了模板和递归的思想,为C++编程提供了高效且灵活的类型操作。此外,文章还展示了如何使用TypeList创建复杂的类层次结构,如GenScatterHierarchy,以实现特定需求的类模板。
摘要由CSDN通过智能技术生成
 套用一个现在很流行的句式,(好多什么编程之美或者代码之美的)。我想看了第三章Modern C++ Design能感受的就是递归之美。而其中主要介绍的TypeList就是这样一个递归演绎的完美的例子。

其实TypeList本身的定义非常简单。就是一个有Head有Tail的一个简单的空的定义
template
struct Typelist
{
typedef T Head;
typedef U Tail;
};
但是如果加上一下这一组宏定义,这个原来的定义就可以无限延伸了

#define LOKI_TYPELIST_1(T1) ::Loki::Typelist
#define LOKI_TYPELIST_2(T1, T2) ::Loki::Typelist
#define LOKI_TYPELIST_3(T1, T2, T3) ::Loki::Typelist

当 然这里的Loki就是本书主要介绍的Loki Library.的名字空间。用过这样的递归的调用你就可以创建出类似的LOKI_TYPELIST_50甚至LOKI_TYPELIST_100。当让 可以让他变的更为强大,强大到随意的添加一个新的类,删除其中的一个类,或者删除冗余的重复。
我们从简单的来看先:

template struct Length;
template <> struct Length
{
enum { value = 0 };
};

template
struct Length<> >
{
enum { value = 1 + Length::value };
};

这 里的实现处处投射出递归的思想,Length这样的模板如何显示出value呢。如果TList是NullType的时候(NullType是这里定义的 一个表示空的类,前面章已有说明),那长度就是0,慢慢来, 如果这个TypeList是TypeList,可以
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值