博客
关于我
【C++常量折叠】改改const试试 _alibaba
阅读量:198 次
发布时间:2019-02-28

本文共 929 字,大约阅读时间需要 3 分钟。

为什么a的值不变,而*p被修改为20?

在C++中,constvolatile 是两个有不同的含义的关键字。const 表示一个变量在编译时被常数替换,而 volatile 表示一个变量的存储单元始终存在于内存中,且值可能在程序运行时发生改变。

在给定的代码中:

const int a = 10;int * p = (int *)(&a);*p = 20;

a 被声明为 const int,这意味着在编译时,a 的值会被替换为 10,而不是分配一个内存块来存储这个值。因此,当我们执行 *p = 20; 时,p 指向 a 的地址,尝试修改 a 的值实际上无法改变内存中 a 的值,因为 a 并没有分配内存。

然而,volatile 的作用是打破常量替换(即 const 的效果),确保变量的值是从内存中直接读取或写入的。因此,当我们在 a 的定义中添加 volatile,如:

volatile const int a = 10;

const volatile int a = 10;

编译器将不会对 a 进行常量替换,而是将 a 分配一个内存块,并初始化为 10。这样,当执行 *p = 20; 时,a 的内存单元会被修改为 20,而不是保持 10 不变。

关于 volatile 的特殊情况

在 VC++ 6.0 中,情况有所不同。即使 a 被声明为 volatile const int a = 10;,VC++ 6.0 的编译器仍然会对 a 进行常量替换。这意味着,尽管 a 被标记为 volatile,但编译器仍然从符号表中获取 a 的值,而不是从内存中读取。因此,在 VC++ 6.0 中,*p = 20; 仍然不会修改 a 的内存值,a 的值仍然保持为 10。

总结

  • const:在编译时替换常数,避免分配内存。
  • volatile:确保变量的值从内存中读取或写入,打破常量替换。
  • VC++ 6.0 的特殊行为:即使 a 被标记为 volatile,VC++ 6.0 仍然对 a 进行常量替换,a 的值不会被修改。

因此,在 VC++ 6.0 中,如果没有添加 volatilea 的值会保持为 10,而 *p 会被修改为 20。

转载地址:http://hpwi.baihongyu.com/

你可能感兴趣的文章
ospf综合实验2 2012/9/8
查看>>
OSPRay 开源项目教程
查看>>
OSS 访问图片资源报“No ‘Access-Control-Allow-Origin‘”的错误
查看>>
oss报UnknownHost,k8s设置hostAliases参数
查看>>
OS模块
查看>>
OS第2章 —— 进程
查看>>
OS第3章 —— 进程调度和死锁
查看>>
OS第5章
查看>>
OS第6章 —— 设备管理
查看>>
OTA测试
查看>>
Outlook 2010 Inside Out
查看>>
overlay(VLAN,VxLAN)、underlay网络、大二层概述
查看>>
OWASP漏洞原理<最基础的数据库 第二课>
查看>>
OWL本体语言
查看>>
P with Spacy:自定义文本分类管道
查看>>
P1035 I need help
查看>>
P1364 医院设置
查看>>
P2260 [清华集训2012]模积和
查看>>
SpringBoot中集成influxdb-java实现连接并操作Windows上安装配置的influxDB(时序数据库)
查看>>
SpringBoot中集成eclipse.paho.client.mqttv3实现mqtt客户端并支持断线重连、线程池高并发改造、存储入库mqsql和redis示例业务流程,附资源下载
查看>>