介绍c++模板编程的很多书,一般上来都拿模板的数值计算举例,这对于
理解模板原理很有帮助,但感觉实际上很少用到,并且存在
一些问题,比如以下是我写的一个用模板进行数值的代码:
#include "stdafx.h"
#include <iostream>
template<int N>
struct Cal
{
static const int value = Cal<N-1>::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很大时,有两个问题:
- 1.内存的消耗是难免的
- 2.编译器报错(比如设N=1000时):recursive type or function dependency context too complex
模板的优势是类型计算,不过真做起项目来恐怕很难用到,算是咱c++
程序员自娱自乐的工具吧~