很久以前曾寫過一個在預處理期算總和的小程式,請見8095
那時才剛懂得一些metaprogramming的皮毛(不過現在懂的招也不多就是)
後來有很長一段時間沒繼續碰,直到boost.preprocessor,又重新鑽進來這個領域
因為boost不是標準庫,於是想試試能否以標準方式,做出一個最簡單的code生成器
用macro做metaprogramming,下面這個應該都是大家遇到的第一個難題,也是最難解決的
#define x 1
#define x x+1//x不會展開成1+1
如果只是要用來展開特定的次數,編譯器有提供自己定義的macro
__COUNTER__:從0開始,每出現一次就加1,visual studio與gcc支援
__INCLUDE_LEVEL__:目前的include深度,僅gcc支援
不過這兩個macro仍然不是標準所提供,若不希望使用
此時就要動用8095以bit來處理的方式
範例如下
#ifndef zzz //一開始會先展開這裡一次
#define C 5 //註1以下的部分展開5次
#include <cstdio>
#include "loop"//裡面包的是8095的bit處理部分,有關token的初始定義
#define zzz x0+x1*2+x2*4+x3*8+x4*16+x5*32+x6*64+x7*128
template<int n> void f(){
printf("%d\n",n);
}
#endif
#if zzz>=C //最後才展開這裡
int main(){
f<0>();
f<1>();
f<2>();
f<3>();
f<4>();
f<5>();
f<6>();
}
#else //註1,反覆展開的部分
#if zzz ==2
#elif zzz ==3
#else //不產生f<2>跟f<3>的特化
template<> void f<zzz>(){
printf("ss:%d\n",zzz);
}
#endif
#include "loop"//裡面包的是8095的bit處理部分,負責讓zzz遞增
#include __FILE__
#endif