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

你可能感兴趣的文章
Nginx配置参数中文说明
查看>>
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
NI笔试——大数加法
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
Nmap扫描教程之Nmap基础知识
查看>>
NMAP网络扫描工具的安装与使用
查看>>
NN&DL4.3 Getting your matrix dimensions right
查看>>
NN&DL4.8 What does this have to do with the brain?
查看>>
No 'Access-Control-Allow-Origin' header is present on the requested resource.
查看>>
No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
查看>>
No module named cv2
查看>>
No module named tensorboard.main在安装tensorboardX的时候遇到的问题
查看>>
No qualifying bean of type XXX found for dependency XXX.
查看>>
No resource identifier found for attribute 'srcCompat' in package的解决办法
查看>>
No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
查看>>
Node JS: < 一> 初识Node JS
查看>>