Re: [问题] 确保#define的值在编译时正确

楼主: LPH66 (-6.2598534e+18f)   2017-07-12 23:07:15
※ 引述《loveflames (咕啾咕啾魔法阵)》之铭言:
: #define FOO_VALUE 5
: #define N5 ~,1
: #define N11 ~,1
: #define N18 ~,1
: #define N21 ~,1
: #define N29 ~,1
: #define Result1 1//5,11,18,21,29
: #define Result0 //其他,0对应到TEST的n
: #define TEST(x,y,n) _TEST(x,y,n)//在串接前先展开x与y
: #define _TEST(x,y,n) __TEST(x##y,n)
: #define __TEST(x,n) ___TEST(x,n)//须多展开一次,不定参数先确认参数数量才展开参数
: #define ___TEST(d,n,...) n
: #define CAT(a,b) _CAT(a,b)
: #define _CAT(a,b) a##b
:
: //上面的code可以独立出来包在header内
:
: #if CAT(Result,TEST(N,FOO_VALUE,0)) > 0
: //不做任何事,Result0会导致编译错误
: #endif
: → Hazukashiine: 底线后面接大写字母是保留给编译器实作的 尽量避免 07/11 18:25
: → Hazukashiine: #define Result0 0 // ... 07/12 01:57
: 推 LPH66: 他就是要 Result0 编译错误...不过倒是可以 #else #error 07/12 04:31
: → loveflames: if/else的写法,如果合法值要改就得改header 07/12 09:21
原本我是想说直接
#if TEST(...) > 0
#else
#error
#endif
这样的, 不过转念一想, 过程中确实能产出一个数字, 那直接就判断数字就好了
还能省去 > 0 跟一个连接; 于是就变成以下这样
#define FOO_VALUE 5 /* 要检查的值 */
#define N5 ~,0 /* 这边都一样, 不过我把 0 和 1 对调 */
#define N11 ~,0
#define N18 ~,0
#define N21 ~,0
#define N29 ~,0
#define TESTNOT(v) _TESTNOT(v) /* 因为 0 1 对调所以改叫 TESTNOT */
#define _TESTNOT(v) SECOND(N##v,1) /* 这里把后半段改叫 SECOND, 然后参数改 1 */
#define SECOND(x,n) _SECOND(x,n)
#define _SECOND(d,n,...) n
#if TESTNOT(FOO_VALUE)
#error Invalid FOO_VALUE!
#endif
而且以情境来看, #error 还能告诉使用者是哪里有问题
作者: loveflames (咕啾咕啾魔法阵)   2017-07-13 09:30:00
推简化

Links booklink

Contact Us: admin [ a t ] ucptt.com