c++ - 为什么我们说#define Processor 在程序中创建多个拷贝?

标签 c++ constants

我刚刚在阅读 Effective C++, 第三版 第 2 项:Prefer const, enum and inline to #define 其中之一给出的原因是在使用 #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 生成的汇编代码。

最佳答案

如果你使用#define 来创建一个像 int 这样的原始类型的命名常量,那没关系,因为预处理器总是“知道”int 是什么,但是在这种情况下,最好使用 const(或c++11 中的 constexpr) 变量,因此编译器将找出类型并进一步优化您的代码。如果您在 #define 中创建一个类对象,情况就不同了,因为如果您在另一个翻译单元中使用它,则会构造另一个对象。

关于c++ - 为什么我们说#define Processor 在程序中创建多个拷贝?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29862152/

相关文章:

c++ - 在复制构造函数中使用 memcpy 复制 QThread 指针

c++ - 按顺时针顺序对图邻接列表中的顶点进行排序

android - 使用 Android NDK 时,Eclipse 编辑器将无法识别 C++ 模板类型

c - 无法释放 C 中的 const 指针

C++ 和 Swift 彼此不喜欢

c++ - 我应该为永远恒定的值创建一个全局常量变量,例如足球运动员的数量吗?

c++ - 对相对路径进行排序

c++ - luabind::object 取消引用的问题(简化)

c++ - 从非常量对象调用 const 函数

c++ - 在 C++14 中,constexpr 成员可以更改数据成员吗?