1,定义宏功能,作,func(x) = x-1?
     最简单的, 假设x = 2则 #define func(x) 1
特化出来x,令
#define func_helper_2 1
#define func(x) func_helper_##x
这样在x=2时就成立了.推广到其它数字仅仅需定义:
#define func_helper_2 1
#define func_helper_3 2
#define func_helper_4 3
...
就可以
得到递减和递增函数
#define DEC(X)
#define INC(X)

2,获取宏可变參数的个数?
看一下这个情况
#define func(a1,a2,a3,a4,...) a4
假设传入func(1,2,3,4,5)会是什么情况?

当然是4
传入func(x,1,2,3,4,5)此时呢?

是3

传入func(x,x,1,2,3,4,5)此时呢? 是2
传入func(x,x,,x,1,2,3,4,5)此时呢? 是1
倒过来呢?
是1,2,3
所以 #define func2(...) func(__VA_ARGES__)就可以

终于得到GET_ELEM_SIZE(X) 为获取5个数内參数个数

3,获取第n个參数?
如 GET_ELEMENT((a1,a2,a3),2)
期望获取到a3?

#define GET_ELEMENT(array,n) GET_ELEMENT_ ## n array
GET_ELEMENT_0(e0,...) e0
GET_ELEMENT_0(e0,e1...) e1
GET_ELEMENT_0(e0,e1,e2...) e2

如此具有了获取三个数以内指定坐标位置的參数了.

4,int转BOOL?

  #define INT_TO_BOOL(X)    INT_TO_BOOL_ ## X
  #define INT_TO_BOOL_0 0  
  #define INT_TO_BOOL_1 1
  #define INT_TO_BOOL_2 1
  #define INT_TO_BOOL_3 1
  #define INT_TO_BOOL_4 1

5,IF分支?
      #define IF_TEST(condition,true_verb,false_verb) IF_TEST_ ## condition (true_verb,false_verb)\
      #define IF_TEST_0(true_verb,false_verb) false_verb
      #define IF_TEST_1(true_verb,false_verb) true_verb

3,iterator?
定义ITER_FUNC(n,context) 为以n为參数的宏函数则:
#define ITERATOR(n,ITER_FUNC,context) ITERATOR_ ## n (ITER_FUNC,context)
#define ITERATOR_0(n,func)
#define ITERATOR_1(func,context) ITERATOR_0(func,context) func(1,context)
#define ITERATOR_2(func,context) ITERATOR_1(func,context) func(2,context)
#define ITERATOR_3(func,context) ITERATOR_2(func,context) func(3,context)
reverse 版本号
#define ITERATOR_REVERSE(n,ITER_FUNC,context) ITERATOR_REVERSE_ ## n (ITER_FUNC,context)
#define ITERATOR_REVERSE_0(n,func)
#define ITERATOR_REVERSE_1(func,context) func(1,context) ITERATOR_REVERSE_0(func,context)
#define ITERATOR_REVERSE_2(func,context) func(2,context) ITERATOR_REVERSE_1(func,context)
#define ITERATOR_REVERSE_3(func,context) func(3,context) ITERATOR_REVERSE_2(func,context)

4,数据结构?
基于上述工具,能够定义出宏的数组结构,能够定义array形式为:
array = (ele0,ele1,ele2)
获取数组大小,可应用情形2:
     #define GET_ARRAY_SIZE(array) GET_ELEM_SIZE array
对数组下标訪问,获取元素:
     #define GET_ARRAY_ELEMENT(array,n) GET_ELEMENT(array,n)
push一个元素:
     #define EXPAND_PARAM(param) param
     #define PUSH_ARRAY_ELEM(array,elem) EXPAND_PARAM array IF_TEST(GET_ARRAY_SIZE(array),EMPTY(),COMMA()) elem
pop 一个元素:
     #define POP_ARRAY_ELEM(array) ITERATOR(DEC(GET_ARRAY_SIZE(array)),COPY_ARRAY_FROM,array)
     #define COPY_ARRAY_FROM(n,array) IF_TEST(n,EMPTY(),COMMA()) GET_ARRAY_ELEMENT(array,n)


举个栗子!
追经典的只是是c++的tuple实现了,还记得那一大堆tuple的參数吗?

回想一下:
\\file tuple.h
template <>
class tuple{}

template <class T1>
class tuple{
     tuple (T1 a1){}
};

template <class T1,class T2>
class tuple{
     tuple (T1 a1,T2){}
};

支持10个參数就要写10个...

使用宏迭代函数:

ITERATOR(2,GEN_TUPLE,pass)

#define GEN_TUPLE(n,pass) \
template <ITERATOR(n,pass,GEN_TPARAM)>\
class tuple{\
     tuple (ITERATOR(n,class T,GEN_PARAM)){}\
};

#define GEN_TPARAM(n,pass) IF_TEST(n,EMPTY(),COMMA()) class T ## n 
#define GEN_PARAM(n,pass) IF_TEST(n,EMPTY(),COMMA()) T ## n a ## n 

版权声明:本文博主原创文章,博客,未经同意不得转载。

c++宏源证券编程的更多相关文章

  1. 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代

    2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...

  2. JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议

    软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...

  3. 读书笔记:JavaScript DOM 编程艺术(第二版)

    读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...

  4. [ 高并发]Java高并发编程系列第二篇--线程同步

    高并发,听起来高大上的一个词汇,在身处于互联网潮的社会大趋势下,高并发赋予了更多的传奇色彩.首先,我们可以看到很多招聘中,会提到有高并发项目者优先.高并发,意味着,你的前雇主,有很大的业务层面的需求, ...

  5. C#异步编程(一)

    异步编程简介 前言 本人学习.Net两年有余,是第一次写博客,虽然写的很认真,当毕竟是第一次,肯定会有很多不足之处, 希望大家照顾照顾新人,有错误之处可以指出来,我会虚心接受的. 何谓异步 与同步相对 ...

  6. UE4新手之编程指南

    虚幻引擎4为程序员提供了两套工具集,可共同使用来加速开发的工作流程. 新的游戏类.Slate和Canvas用户接口元素以及编辑器功能可以使用C++语言来编写,并且在使用Visual Studio 或 ...

  7. C#与C++的发展历程第三 - C#5.0异步编程巅峰

    系列文章目录 1. C#与C++的发展历程第一 - 由C#3.0起 2. C#与C++的发展历程第二 - C#4.0再接再厉 3. C#与C++的发展历程第三 - C#5.0异步编程的巅峰 C#5.0 ...

  8. 猫哥网络编程系列:HTTP PEM 万能调试法

    注:本文内容较长且细节较多,建议先收藏再阅读,原文将在 Github 上维护与更新. 在 HTTP 接口开发与调试过程中,我们经常遇到以下类似的问题: 为什么本地环境接口可以调用成功,但放到手机上就跑 ...

  9. 关于如何提高Web服务端并发效率的异步编程技术

    最近我研究技术的一个重点是java的多线程开发,在我早期学习java的时候,很多书上把java的多线程开发标榜为简单易用,这个简单易用是以C语言作为参照的,不过我也没有使用过C语言开发过多线程,我只知 ...

随机推荐

  1. MIPS平台目标机安装Oprofile时出现error

    在Debian下安装Oprofile 重要:应该使linux内核选项支持 在 .config 文件中设置CONFIG_PROFILING=y和CONFIG_OPROFILE=y. 重新编译,烧写.使用 ...

  2. Java排序算法(四):Shell排序

    [基本的想法] 将原本有大量记录数的记录进行分组.切割成若干个子序列,此时每一个子序列待排序的记录个数就比較少了,然后在这些子序列内分别进行直接插入排序,当整个序列都基本有序时.再对全体记录进行一次直 ...

  3. codeforces 598A Tricky Sum

    题目链接:http://codeforces.com/contest/598/problem/A 题目分类:大数 题意:1到n 如果是2的次方则减去这个数,否则就加上这个数,求最后的结果是多少 题目分 ...

  4. [Android学习笔记]LayoutInflater的使用

    LayoutInflater用于动态载入布局,然后获取到布局中定义完成的控件引用 常在动态加载布局,和Adapter中用到 使用步骤:1.通过LayoutInflater加载xml布局文件2.从载入的 ...

  5. hdu1217Arbitrage--解题报告

    题意:套利,一个US币换取0.5 British pound,而1 British pound 换取10.0 French francs,同一时候 1 French franc buys 0.21 U ...

  6. hdu 3832 Earth Hour (最短路变形)

    Earth Hour Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 125536/65536 K (Java/Others) Tota ...

  7. POJ 2318 TOYS(计算几何)

    跨产品的利用率推断点线段向左或向右,然后你可以2分钟 代码: #include <cstdio> #include <cstring> #include <algorit ...

  8. 怎样处理iOS 5与iOS 6的 low-memory

    移动设备终端的内存极为有限,应用程序必须做好low-memory处理工作,才能避免程序因内存使用过大而崩溃. low-memory 处理思路 通常一个应用程序会包含多个view controllers ...

  9. 给一个非常长的字符串str 另一个字符集比方{a,b,c} 找出str 里包括{a,b,c}的最短子串。要求O(n)

    给一个非常长的字符串str 另一个字符集比方{a,b,c} 找出str 里包括{a,b,c}的最短子串.要求O(n). 比方,字符集是a,b,c,字符串是abdcaabcx,则最短子串为abc. 设置 ...

  10. Accord.Net中决策树

    Accord.Net中决策树 决策树介绍 决策树是一类机器学习算法,可以实现对数据集的分类.预测等.具体请阅读我另一篇博客(http://www.cnblogs.com/twocold/p/54245 ...