c ++テンプレートメタプログラミングは関数型プログラミングの一形態ですか?もしそうなら、c ++テンプレートメタプログラミングに関連する非末尾再帰のスタックオーバーフローのようないくつかの落とし穴はありますか?
この質問の階乗テンプレートの例では、標準の関数型プログラミングだと思います。または、類似性は表面的なものにすぎませんか?
#include <iostream>
using namespace std;
template< int n >
struct factorial { enum { ret = factorial< n - 1 >::ret * n }; };
template<>
struct factorial< 0 > { enum { ret = 1 }; };
int main() {
cout << "7! = " << factorial< 7 >::ret << endl; // 5040
return 0;
}