使用预处理器在C中进行模板化
我想知道为什么我以前从未见过以下方法在C中实现模板。 我的想法是让预处理器成为模板工作。
container.h :
#ifndef TEMPLATE_TYPE #error "missing decalaration TEMPLATE_TYPE" #endif #define _CONCAT(a, b) a##b #define _EVALUATOR(a, b) _CONCAT(a, b) #define MAKE_NAME(a, b) _EVALUATOR(a, b) typedef struct { TEMPLATE_TYPE data; } MAKE_NAME(Container_, TEMPLATE_TYPE);
main.c :
#define TEMPLATE_TYPE int #include "container.h" int main() { Container_int c; c.data = 99923; }
那么,情况如何呢?
- 这只是被认为是“坏风格”
- 很明显,没有人会写一篇关于它的文章
- 有很多文章,只是google man!
如果您不打算用#3回答,我将非常感谢您对此技术的评论。
你可以使用预处理器做出令人难以置信的事情(善与恶)。 它是否被认为是不好的风格是判断调用,它在很大程度上取决于所产生的代码的质量,可读性和可维护性。 复杂的预处理器宏很难编写,调试和维护。 但是,最好的C代码是您不编写的代码,宏非常适合自动生成主题的变体。
以下是预处理器(ab)使用的一些很好的例子:
- SimpleScalar处理器模拟器的machine.def文件 (尽管有扩展名,但它是C代码)
- 规范queue.h链表头
SimpleScalar代码使用类似于上面建议的模式,其中#include前面带有一个#define,它给标题指定了一些方向。
如果您正在考虑认真使用预处理器,那么您应该查看Boost预处理器库 。 (不要被Boost的C ++根推迟,预处理器宏可以与C一起工作。)
代替
typedef struct { TEMPLATE_TYPE data; } MAKE_NAME(Container_, TEMPLATE_TYPE)
你可能想做
#define MAKE_CONTAINER(type) typedef struct MAKE_NAME(Container_, type) { type data; } MAKE_NAME(Container_, type)
为了能够做到
#include "container.h" MAKE_CONTAINER(int); MAKE_CONTAINER(double); int main() { Container_int c; // one way to go struct Container_double d; // my preferred way: don't typedef when not needed; let the structs be obvious. c.data = 99923; d.data = 3.5; }