注意const是运行期常量,constexpr是编译器常量。
下面的代码在C++ 11, LINUX 4.15.0-88-generic编译结果为
0x7fff91706d98
0x7fff91706d9c
456
123 //编译器优化
456
123 //编译器优化
后面2个123是因为编译器加了优化,看到是const和constexpr就直接把结果输出为123了。
采用g++ -O0 const1.cpp 关掉编译器优化,效果还是一样。可能有些平台上可以。
#include <iostream>
using namespace std;
int main() {
const int x = 123;
constexpr int y = 123;
*(const_cast<int *>(&x)) = 456;
*(const_cast<int *>(&y)) = 456;
cout << &x << endl;
cout << &y << endl;
cout << *(const_cast<int *>(&x)) << endl;
cout << *(&x) << endl;
cout << *(const_cast<int *>(&y)) << endl;
cout << *(&y) << endl;
return 0;
}
那么怎么防止编译器优化呢?
解决办法1:采用指针转换,123就变成456了。
const char *p = (const char *)&x;
cout << *(int *)p << endl;
解决办法2:定义为volatile,编译器就不会加优化了。
const volatile int x = 123;
constexpr volatile int y = 123;