博客
关于我
【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/

你可能感兴趣的文章
Node响应中文时解决乱码问题
查看>>
node基础(二)_模块以及处理乱码问题
查看>>
node安装卸载linux,Linux运维知识之linux 卸载安装node npm
查看>>
node安装及配置之windows版
查看>>
Node实现小爬虫
查看>>
Node提示:error code Z_BUF_ERROR,error error -5,error zlib:unexpected end of file
查看>>
Node提示:npm does not support Node.js v12.16.3
查看>>
Node搭建静态资源服务器时后缀名与响应头映射关系的Json文件
查看>>
Node服务在断开SSH后停止运行解决方案(创建守护进程)
查看>>
node模块化
查看>>
node模块的本质
查看>>
node环境下使用import引入外部文件出错
查看>>
node环境:Error listen EADDRINUSE :::3000
查看>>
Node的Web应用框架Express的简介与搭建HelloWorld
查看>>
Node第一天
查看>>
node编译程序内存溢出
查看>>
Node读取并输出txt文件内容
查看>>
node防xss攻击插件
查看>>
noi 1996 登山
查看>>
noi 7827 质数的和与积
查看>>