我只是在第2项:首选const,枚举和内联到#define 之一阅读有效C ++, 第三版给出的原因是在使用#define
时,预处理器在我们的目标代码中创建#define
的多个副本。我真的没有得到这个为什么预处理器会创建#define
的多个副本?因为我所知道的只是它取代了发现那个宏的地方。
当我为我的代码创建汇编代码时,我几乎得到了相同的汇编代码?
例如:
int main()
{
const int MAGICNUM 5;
int i=MAGICNUM*1;
int j=MAGICNUM*2;
int k=MAGICNUM*3;
int l=MAGICNUM*4;
int m=MAGICNUM*5;
}
相应的汇编代码:
0004 C745E805 movl $5, -24(%rbp)
000000
000b C745EC05 movl $5, -20(%rbp)
000000
0012 C745F00A movl $10, -16(%rbp)
000000
0019 C745F40F movl $15, -12(%rbp)
000000
0020 C745F814 movl $20, -8(%rbp)
000000
0027 C745FC19 movl $25, -4(%rbp)
000000
即使我使用#define,我也得到相同的代码。使用assembly.ynh.io生成的汇编代码。
答案 0 :(得分:0)
如果你使用#define创建一个像int这样的基本类型的命名符号,因为预处理器总是“知道”int是什么,但是在这种情况下使用const是个好主意(或者constexpr in c ++ 11)变量,因此编译器将找出类型并进一步优化您的代码。如果在#define中创建一个类对象,情况会有所不同,因为如果你在另一个翻译单元中使用它,则会构造另一个对象。