读loki有感,TYPEList原理

简介: 读loki有感,TYPEList原理

问题一,简化版的TYPEList,只支持int型

template<int n>
class TYPEList
{
public:
 int Head;
 TYPEList<n-1> Tail;
};
template<>
class TYPEList<0>
{
public:
 int Tail;
 int Head; 
};


测试代码

TYPEList<0> l0;
 l0.Head = 1;
 l0.Tail = 2;
TYPEList<2> l2;
l2.Head = 3;
l2.Tail.Head = 4;
l2.Tail.Tail.Head = 5;
l2.Tail.Tail.Tail = 6;

问题二:可以同过GetAt(int)获取值

template<int n>
class TYPEList
{
public:
 int Head;
 TYPEList<n-1> Tail;
 int GetAt(int index )
 {
  if( n+1 == index )
   return Head;
  return Tail.GetAt(index);
 }
};
template<>
class TYPEList<0>
{
public:
 int GetAt(int index)
 {
  if( 1 == index )
   return Tail;
  return Head;
 }
 int Tail;
 int Head; 
};

测试代码

TYPEList<0> l0;
 l0.Head = 1;
 l0.Tail = 2;
 TYPEList<2> l2;
 l2.Head = 3;
 l2.Tail.Head = 4;
 l2.Tail.Tail.Head = 5;
 l2.Tail.Tail.Tail = 6;
 int i1 = l2.GetAt(0);
 int i2 = l2.GetAt(1);
 int i3 = l2.GetAt(2);
 int i4 = l2.GetAt(3);


问题三,类型不再限于int,但最多集成3个变量。


class NullType
{
};
template <class T, class U>
struct Typelist
{
 T Head;
 U Tail;
};
template <typename T1  = NullType, typename T2  = NullType, typename T3  = NullType >
struct MakeTypelist
{ 
private:  
 typedef typename MakeTypelist< T2 ,T3>::Result TailResult; 
public:  
 typedef Typelist<T1, TailResult> Result; };
template<> 
struct MakeTypelist<> 
 {  
  typedef NullType Result;
 };

测试代码:

MakeTypelist<ULONG,CString,int>::Result User,User2;
 User.Head = 1;
 User.Tail.Head = "何志丹";
 User.Tail.Tail.Head = 35;
 User2 = User;
 template <class AtomicType, template <class> class GenFunc>
    struct IterateTypes
   {    template<class II>
    void operator()(II ii)
       {   
    GenFunc<AtomicType> genfunc;
        *ii = genfunc();
        ++ii; //Is this even needed?
        }
    };
相关文章
|
7月前
|
存储 JSON 监控
可以通过配置Filebeat来将Higress日志持久化到磁盘
【2月更文挑战第10天】可以通过配置Filebeat来将Higress日志持久化到磁盘
107 4
|
4月前
|
应用服务中间件 nginx Docker
[loki]轻量级日志聚合系统loki快速入门
[loki]轻量级日志聚合系统loki快速入门
186 5
|
7月前
|
监控 固态存储 安全
源码剖析:Elasticsearch 段合并调度及优化手段
源码剖析:Elasticsearch 段合并调度及优化手段
87 0
|
7月前
|
存储 算法 关系型数据库
带你读《存储漫谈:Ceph原理与实践》精品文章合集
带你读《存储漫谈:Ceph原理与实践》精品文章合集
|
7月前
|
存储 测试技术 索引
「译文」Loki 简明指南:如何处理失序和较旧的日志
「译文」Loki 简明指南:如何处理失序和较旧的日志
|
存储 JSON 缓存
K8s日志组件-Loki是如何存储数据的?
日志记录本质上是一个事件。大多数语言、应用程序框架或库都支持日志,表现形式可以是字符串这样原始的非结构化数据,也可以是JSON等半结构化数据。开发者可以通过日志来分析应用的执行状况,报错信息,分析性能…… 正因为日志极其灵活,生成非常容易,没有一个统一的结构,所以它的体量也是最大的。
546 0
|
存储 容灾 负载均衡
带你读《存储漫谈:Ceph原理与实践》——3.3.1 MDS 设计原理
带你读《存储漫谈:Ceph原理与实践》——3.3.1 MDS 设计原理
|
存储 Swift 索引
带你读《存储漫谈:Ceph原理与实践》——2.1 数据寻址方案
带你读《存储漫谈:Ceph原理与实践》——2.1 数据寻址方案
|
存储 算法 网络性能优化
带你读《存储漫谈:Ceph原理与实践》——3.1.5 QoS
带你读《存储漫谈:Ceph原理与实践》——3.1.5 QoS

热门文章

最新文章