设为首页 加入收藏

TOP

C++拾遗--模板元编程
2015-02-25 16:15:08 来源: 作者: 【 】 浏览:21
Tags:拾遗 模板 编程

前言


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


模板元编程


#include
#include
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
struct Data
{
?enum{ res = Data::res + Data::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语言梳理一下,分布在以下10个章节中:


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Java实现循环列表解决约瑟夫环问题 下一篇C++拾遗--name_cast 显式类型转换

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: