所以,根据这个answer , C++ 不支持可变参数宏,C++ 标准也没有在任何地方提到可变参数宏。我知道 C99 引入了带有 __VA_ARGS__
的可变参数宏,某些 C++ 编译器(如 GCC)甚至提供扩展以在 C++ 中允许这样做,但事实仍然是可变参数宏根本不是标准 C++ 的一部分。
现在,Boost.Fusion 中有一个功能,您可以使用 BOOST_FUSION_ADAPT_STRUCT
将 Fusion 序列绑定(bind)到任意类或结构。宏。这使您可以像使用 Fusion 序列一样使用您的类或结构。
这是一个如何使用它的例子(取自 Boost 文档):
namespace demo
{
struct employee
{
std::string name;
int age;
};
}
// demo::employee is now a Fusion sequence
BOOST_FUSION_ADAPT_STRUCT(
demo::employee,
(std::string, name)
(int, age))
现在,如果没有可变参数宏,这段代码怎么可能呢? BOOST_FUSION_ADAPT_STRUCT
宏似乎可以接受任意数量的参数,因为据推测它可以与任意用户定义的类或结构一起使用。
我知道 Boost 以以有趣的方式改变 C++ 而闻名,但如果没有编译器支持,这似乎是完全不可能的。那么 Boost.Fusion 做了什么样的魔法来实现这一目标?
PS:是的,我知道 Boost 是开源的。我做的第一件事是查看源代码。它似乎正在使用 Boost Preprocessor 库以某种方式连接宏。但我不明白这如何适用于任意数量的参数,源代码是一个非常密集的预处理器代码集合,很难理解。
最佳答案
BOOST_FUSION_ADAPT_STRUCT(
demo::employee,
(std::string, name)
(int, age))
这是一个带有两个参数的宏: 参数 1:demo::employee 参数 2:(std::string, name)(int, age)
参数 2 与字符串连接形成另一个宏调用,它也有 2 个参数:
BOOST_FUSION_SOME_INTERNAL_MACRO(std::string, name)
BOOST_FUSION_SOME_INTERNAL_MACRO(int, age)
关于Boost.Fusion 中的 C++ 可变参数宏?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6046228/