元编程

什么是元编程(metaprogramming)

  • 利用模板可以进行编译期计算(数值计算,型式计算和代码计算)的特点进行程序设计

为什么可以进行元编程?

  • C++是两层语言:执行编译期计算的代码称为静态代码,执行运行期计算的代码称为动态代码
  • 模板可用于函数式编程,强调抽象计算,重视模块化,使用递归控制流程
  • 模板是图灵完备的:理论上,模板可以执行任何计算任务

为什么需要元编程?

  • 编译期计算可以使代码更通用,更易用,提升程序执行性能

元编程的缺点

  • 相对结构化编程,编译效率比较低
  • 代码丑陋不堪,阅读难,调试难,维护难,易导致代码膨胀

元编程可以做什么?

  • 数值序列计算,素性判断,控制结构,循环展开,型式判定,编译期多态,标签,元容器...

注:对于系统编程而言,意义不明显;

//Fibonacci数列
#include <iostream>
//类模板,计算Fibonacci数列的第i项
template<int i = > class Fibonacci
{
public:
enum{value = Fibonacci<i->::value + Fibonacci<i->::value};
};
//类模板特化,递归终止条件
template<> class Fibonacci<> {public:enum{value = }; };
template<> class Fibonacci<> {public:enum{value = }; };
int main()
{
std::cout << "Fib(" << << ")=" << Fibonacci<>::value << std::endl;
std::cout << "Fib(" << << ")=" << Fibonacci<>::value << std::endl;
std::cout << "Fib(" << << ")=" << Fibonacci<>::value << std::endl;
std::cout << "Fib(" << << ")=" << Fibonacci<>::value << std::endl; return ;
}

例子2:素数枚举

#include <iostream>
#include <iomanip>
//递归计算p是否为素数;若是,素数判定结论answer为1,否则为0
template<int p, int i> struct PrimeMagicCube
{
enum{answer = p%i && PrimeMagicCube<p,i->::answer};
};
//素数魔方类模板部分特化,递归终止条件,除数为1,没有找到因子
template<int p>struct PrimeMagicCube<p,>
{
enum{answer = };
};
//数值类模板,输出不大于i的全部素数
template<int i> struct Number
{
Number<i - > a;//递归定义数值对象
enum {answer = PrimeMagicCube<i,i->::answer};
void IsPrime()
{
//先降序输出全部素数,后升序输出全部数值素性序列
if (answer) std::cout << std::setw() << std::right << i;
a.IsPrime();//递归调用,计算下一数值的素性
std::cout << std::setw() << answer;
}
}; //数值类模板特化,终止于2
template<> struct Number<>
{
enum{answer = };
void IsPrime()
{
std::cout << std::setw() << std::right << << std::endl;
std::cout << std::setw() << answer;
}
}; int main()
{
Number<> a;//输出100内的所有素数
a.IsPrime();
std::cout << std::endl;
}

C++学习笔记37:元编程的更多相关文章

  1. 孙鑫VC学习笔记:多线程编程

    孙鑫VC学习笔记:多线程编程 SkySeraph Dec 11st 2010  HQU Email:zgzhaobo@gmail.com    QQ:452728574 Latest Modified ...

  2. Hadoop学习笔记(7) ——高级编程

    Hadoop学习笔记(7) ——高级编程 从前面的学习中,我们了解到了MapReduce整个过程需要经过以下几个步骤: 1.输入(input):将输入数据分成一个个split,并将split进一步拆成 ...

  3. WCF学习笔记之事务编程

    WCF学习笔记之事务编程 一:WCF事务设置 事务提供一种机制将一个活动涉及的所有操作纳入到一个不可分割的执行单元: WCF通过System.ServiceModel.TransactionFlowA ...

  4. java学习笔记15--多线程编程基础2

    本文地址:http://www.cnblogs.com/archimedes/p/java-study-note15.html,转载请注明源地址. 线程的生命周期 1.线程的生命周期 线程从产生到消亡 ...

  5. java学习笔记14--多线程编程基础1

    本文地址:http://www.cnblogs.com/archimedes/p/java-study-note14.html,转载请注明源地址. 多线程编程基础 多进程 一个独立程序的每一次运行称为 ...

  6. IOS学习笔记37——ViewController生命周期详解

    在我之前的学习笔记中讨论过ViewController,过了这么久,对它也有了新的认识和体会,ViewController是我们在开发过程中碰到最多的朋友,今天就来好好认识一下它.ViewContro ...

  7. Python学习笔记6 函数式编程_20170619

    廖雪峰python3学习笔记: # 高阶函数 将函数作为参数传入,这样的函数就是高阶函数(有点像C++的函数指针) def add(x, y): return x+y def mins(x, y): ...

  8. IOS学习笔记之 Socket 编程

    最近开始静心学习IOS编程,虽然起步有点晚,但有句话说的好:“如果想去做,任何时候都不晚”.所以在今天,开始好好学习IOS.(本人之前4年都是搞.Net的,java也培训过一年) 打算学IOS,从哪入 ...

  9. javascript 学习笔记之模块化编程

    题外: 进行web开发3年多了,javascript(后称js)用的也比较多,但是大部分都局限于函数的层次,有些公共的js函数可重用性不好,造成了程序的大量冗余,可读性差(虽然一直保留着注释的习惯,但 ...

随机推荐

  1. Android 自定义View修炼-高仿猎豹清理大师自定义内存开口圆环比例进度View

    一.概述 看见猎豹清理大师的内存开口圆环比例进度 挺有意思的,于是就是想自己实现下这样的效果,于是反编译了猎豹清理 大师的app看了下,原来是有两张图,于是脑子里就过了下思路,利用上下两张图,旋转上面 ...

  2. Android View的绘制机制流程深入详解(三)

    本系列文章主要着重深入介绍Android View的绘制机制及流程,第三篇主要介绍并分析视图状态以及重绘流程,首先剖析了 视图的几种状态,然后在深入分析视图的重绘机制流程. 真题园网:http://w ...

  3. sass+require实现侧边栏

    一.效果图(如下)及使用的技术 实现用sass实现页面中右侧固定侧边栏的样式,用require.js实现返回顶部的功能 二.sass 具体的sass的介绍就不多说了,大家可以参考sass官网介绍,下面 ...

  4. ListVIew中插入view

    public class MainActivity extends Activity { private ListView listview; private List<String> d ...

  5. Android_AsyncTask_json

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools= ...

  6. 常用ASP函数的封装

    做ASP开发常常需要用到一些小功能,这些功能通常我们都会封装成函数来使用,本教程提供了许多我们经常用到的ASP函数. <% '所有功能函数名如下: ' StrLength(str) 取得字符串长 ...

  7. Windows Azure入门教学:使用Blob Storage

    对于.net开发人员,这是一个新的领域,但是并不困难.本文将会介绍如何使用Blob Storage.Blob Storage可以看做是云端的文件系统.与桌面操作系统上不同,我们是通过REST API来 ...

  8. 【重叠I/O之系列三】I/O完成端口

    一   串行模式和并行模式 一般一个服务应用程序采用以下两个架构模型之一: 串行模式  一个线程等待一个客户发出的请求,当请求到达的时候,线程会被换醒来处理客户的请求. 并发模式.一个线程等待一个客户 ...

  9. 虚拟光驱 DAEMON Tools Lite ——安装与入门

    DAEMON Tools Lite 是什么?它不仅仅是虚拟光驱.是的,你可以使用它制作.加载光盘映像,但是 DAEMON Tools 产品那么多,Lite版与其他版本究竟有什么不同呢?或者说,是什么让 ...

  10. Sql 解释

    SQL(Structured Query Language) 结构化查询语言,虽然是查询语言,也是一种编程语言,但是执行查询操作. 根据数据的操作对象,可以将SQL语句分为几类. DDL(Data D ...