Ответ 1
Для вашего второго #define вам нужно использовать оператор # препроцессора, например:
#define myDefine(a) myFunc(a, #a);
Это преобразует аргумент в строку.
Предположим, вы хотите создать сопоставленный список идентификаторов и строк
enum
{
NAME_ONE,
NAME_TWO,
NAME_THREE
};
myFunction(NAME_ONE, "NAME_ONE");
myFunction(NAME_TWO, "NAME_TWO");
myFunction(NAME_THREE, "NAME_THREE");
.. без повторения себя и без автоматического генерации кода с использованием макросов C/С++
Исходная предпосылка:
Вы можете добавить файл #include, содержащий
myDefine(NAME_ONE)
myDefine(NAME_TWO)
myDefine(NAME_THREE)
Затем используйте его дважды:
#define myDefine(a) a,
enum {
#include "definitions"
}
#undef myDefine
#define myDefine(a) myFunc(a, "a");
#include "definitions"
#undef myDefine
но #define не позволяет помещать параметры в строку?
Для вашего второго #define вам нужно использовать оператор # препроцессора, например:
#define myDefine(a) myFunc(a, #a);
Это преобразует аргумент в строку.
Здесь хороший способ объявить список имен:
#define FOR_ALL_FUNCTIONS(F)\
F(NameOne)\
F(NameTwo)\
F(NameThree)\
#define DECLARE_FUNCTION(N)\
void N();
#define IMPLEMENT_FUNCTION(N)\
void N(){}
FOR_ALL_FUNCTIONS(DECLARE_FUNCTION);
FOR_ALL_FUNCTIONS(IMPLEMENT_FUNCTION);
Таким образом, этот список имен можно повторно использовать несколько раз. Я использовал его для прототипирования новых языковых функций, хотя никогда не использовал их. Итак, если ничего другого, они были отличным способом найти тупики в собственных изобретениях. Интересно, если это потому, что они говорят: "макросы плохие"...:)