慎用模板计算

介绍c++模板编程的很多书,一般上来都拿模板的数值计算举例,这对于理解模板原理很有帮助,但感觉实际上很少用到,并且存在一些问题,比如以下是我写的一个用模板进行数值的代码:


#include "stdafx.h"
#include

template
struct Cal
{
static const int value = Cal::value + N;
};

template<>
struct Cal<1>
{
static const int value = 1;
};

using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
cout << Cal<100>::value << endl;
return 0;
}

在计算Cal<100>::value时,会调用 Cal<100-1>::value + N,实例化模板Cal<99>, 这样一层层的递归下去直到Cal<1>为止,这意味着编译器会生成从Cal<1>到Cal<100>这100个结构体,当N很大时,有两个问题:
[list]
[*]1.内存的消耗是难免的
[*]2.编译器报错(比如设N=1000时):recursive type or function dependency context too complex[/list]
模板的优势是类型计算,不过真做起项目来恐怕很难用到,算是咱c++程序员自娱自乐的工具吧~

你可能感兴趣的:(c++)