【发布时间】:2016-10-28 01:20:53
【问题描述】:
假设我们有一个std::aligned_storage 的实现。我为alignof 和alignas 运算符定义了两个宏。
#include <iostream>
#include <cstddef>
#define ALIGNOF(x) alignof(x)
#define ALIGNAS(x) alignas(x)
template<std::size_t N, std::size_t Al = ALIGNOF(std::max_align_t)>
struct aligned_storage
{
struct type {
ALIGNAS(Al) unsigned char data[N];
};
};
int main()
{
// first case
std::cout << ALIGNOF(aligned_storage<16>::type); // Works fine
// second case
std::cout << ALIGNOF(aligned_storage<16, 16>::type); // compiler error
}
在第二种情况下,我得到问题标题中的错误(使用 Clang 编译,使用 GCC 时出现类似错误)。如果我分别用alignof 和alignas 替换宏,则该错误不存在。 这是为什么?
在你开始问我为什么要这样做之前 - 原始宏具有 C++98 兼容代码,例如 __alignof 和 __attribute__((__aligned__(x))) 并且这些是特定于编译器的,所以宏是我唯一的选择...
编辑: 因此,根据标记为重复的问题,额外的一组括号将解决该问题。
std::cout << ALIGNOF((aligned_storage<16, 16>::type)); // compiler error
它没有。 那么,我该怎么做呢? (令人满意的问题?)
【问题讨论】:
-
@melpomene,这并不能真正解决问题
-
为什么?因为逗号。 - 宏扩展在对任何其他内容产生句法意义之前看到逗号
-
顺便说一句 - 只需使用
#define MACRO(...) something(__VA_ARGS__)来解决它。 -
额外的括号仅适用于表达式。您正在处理类型/参数列表,因此需要不同的解决方法。