码迷,mamicode.com
首页 > 编程语言 > 详细

C++拾遗--模板元编程

时间:2015-02-19 16:22:17      阅读:284      评论:0      收藏:0      [点我收藏+]

标签:模板元   递归   内联函数   编译   

                          C++拾遗--模板元编程

前言

    模板元是用于递归加速的,把运行期的函数调用变到编译期进行代码展开,类似于内联函数。下面看一个实例:斐波那契数列第n项求解。

模板元编程

#include <iostream>
#include <ctime>
using namespace std;
//递归法
int fib(int n)
{
	if (n < 0)
		return 0;
	if (n == 1 || n == 2)
		return 1;
	return fib(n - 1) + fib(n - 2);
}
//模板元
template<int N>
struct Data
{
	enum{ res = Data<N-1>::res + Data<N-2>::res };
};
template<>
struct Data<1>
{
	enum{ res = 1 };
};
template<>
struct Data<2>
{
	enum{ res = 1 };
};
int main()
{
	cout << "******模板元编程***by David***" << endl;
	time_t start, end;
	start = clock();
	cout << fib(40) << endl;
	end = clock();
	cout << "递归法耗时" << end - start << "ms" << endl;
	start = clock();
	cout << Data<40>::res << endl;
	end = clock();
	cout << "模板元法耗时" << end - start << "ms" << endl;
	cin.get();
	return 0;
}
运行

技术分享

总结:

递归法耗时较久。模板元法的运行时间是有问题的,在VS上把鼠标移到Data<40>::res时就可以看到结果。




本专栏目录

所有内容的目录



C++拾遗--模板元编程

标签:模板元   递归   内联函数   编译   

原文地址:http://blog.csdn.net/zhangxiangdavaid/article/details/43701669

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!