Скажем, у нас есть реализация 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 совместимый код C++, такие как __alignof
и __attribute__((__aligned__(x)))
и те компилятор конкретные, поэтому макросы мой единственный выбор ...
EDIT: Так что в соответствии с вопросом, обозначенным как дубликат, дополнительный набор скобок исправит проблему.
std::cout << ALIGNOF((aligned_storage<16, 16>::type)); // compiler error
Это не так. Итак, как я могу это сделать? (Удовлетворительный вопрос?)
@melpomene, Это действительно не дает возможности решить проблему – chris
Почему? Потому что запятая. - Расширение макросов видит запятую, прежде чем делать синтаксический смысл любого другого контента. –
http://stackoverflow.com/questions/679979/how-to-make-a-variadic-macro-variable-number-of-arguments может быть полезным –