Скажем, что у нас есть реализация 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
соответственно. Почему это?
Прежде чем вы начнете спрашивать меня, почему я это делаю - исходные макросы имеют совместимый с С++ 98 код, такой как __alignof
и __attribute__((__aligned__(x)))
, и они специфичны для компилятора, поэтому макросы - это мой единственный выбор...
EDIT: Поэтому в соответствии с вопросом, обозначенным как дубликат, дополнительный набор скобок исправит проблему.
std::cout << ALIGNOF((aligned_storage<16, 16>::type)); // compiler error
Это не так. Итак, как я буду заниматься этим? (Запрашиваемый вопрос?)