c++ volatile

用 volatile前

int main()
{     

    const int a = 1;
    int *p;
    p = const_cast<int*>(&a);
    (*p)++;
    cout << a << endl;
    cout << *p << endl;
    cout << "end mycast" << endl;
}

结果:(如果你调试会发现 p 和&a的 地址其实是一样的。调试的a的值也是2,打印出来却是1)

mycast
1
2
end mycast

用 volatile后

int main()
{     

    volatile const int a = 1;
    int *p;
    p = const_cast<int*>(&a);
    (*p)++;
    cout << a << endl;
    cout << *p << endl;
    cout << "end mycast" << endl;
}

结果:

mycast
2
2
end mycast

编译器优化之后,编译器会将常变量假定为一个不会被修改的值。

一般情况下的变量在使用的时候要从内存中取最新的值到寄存器中使用,

而常变量编译器则认为其不会被修改,所以直接读取寄存器中保存的值。而寄存器先保存,我们再继续修改,就导致即使修改了内存中的值,编译器也不会去取内存中的值。使用volatile关键字也可以避免编译器优化导致错误。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值