volatile 和const 变量的使用

一。volatile定义:

一个定义为volatile的变量是说这变量可能会被意想不到的被改变,这样,有了volatile变量后,就提醒编译器就不会去假设这个变量的值了。精确地说就是,编译中的优化器在用到这个变量时必须每次都小心地重新读取这个变量的值,而不是使用保存在寄存器里的备份。

eg:

1.硬件设备的寄存器(如:状态寄存器)

#define GPFCON (*(volatile unsigned long *)0x56000050)

2.一个中断服务子程序中会访问到的非自动变量(Non-automatic variables)

3.多线程应用中被几个任务共享的变量

二。const定义:

const是一个C语言的关键字,它限定一个变量不允许被改变

eg:

1.定义const常量,具有不可变性。

const int i=0; i++将报错;

2. 可以保护被修饰的东西,防止意外的修改,增强程序的健壮性。 如下面的例子,如果在函数体内修改了i,编译器就会报错;

void function(const int i) { i=10;//error! }

3. 提高了程序执行效率。

编译器通常不为普通const常量分配存储空间,而是将它们保存在符号表中,这使得它成为一个编译期间的常量,没有了存储与读内存的操作,使得它的效率也很高。

4.可以避免意义模糊的数字出现,同样可以很方便地进行参数的调整和修改。 同宏定义一样,可以做到不变则已,一变都变!

const int i=0
如果想修改i的内容,只需要:

const int i=xxxxx;

5.便于进行类型检查,使编译器对处理内容有更多了解,消除了一些隐患。

void function(const int i) { .........} 编译器就会知道i是一个常量,不允许修改;

三。volatile和const混用

const和volatile放在一起的意义在于:

(1)本程序段中不能对a作修改,任何修改都是非法的,或者至少是粗心,编译器应该报错,防止这种粗心;
(2)另一个程序段则完全有可能修改,因此编译器最好不要做太激进的优化。

“const”含义是“请做为常量使用”,而并非“放心吧,那肯定是个常量”。
“volatile”的含义是“请不要做没谱的优化,这个值可能变掉的”,而并非“你可以修改这个值”。
因此,它们本来就不是矛盾的。

const修饰的变量不允许这里修改不代表不允许别处修改,比如:
int i = 5;
const int* p = &i;
i = 6; // 不可以;
*p = 7; // 完全可以,而且那个“const”的“*p”也跟着变成了7。

对于非指针非引用的变量,const volatile同时修饰的意义确实不大。个人觉得。

需要明白“volatile”的含义并非是“non-const”。所以他们才可以放在一起。
在C++语言中,const没有反义词,如果一个变量没有const修饰,那它本身就是const的反义词,而并非加上volatile才是const的反义词。

两者同时修饰一个对象的典型情况,是用于驱动中访问外部设备的只读寄存器。

部分引用:http://blog.csdn.net/qq306013411/article/details/8013044

时间: 2024-11-02 19:49:45

volatile 和const 变量的使用的相关文章

程序猿之---C语言细节28(const变量初始化、数组大小用const变量细节、const变量与#define宏、volatile修饰)

主要内容:const变量初始化.数组大小用const变量细节.const变量与#define宏.volatile修饰 一.const变量初始化时必须赋值 二.const变量在C++中可以做数组大小元素.在C中不行,因为它是变量 三.const和#define区别:内存分配 四.volatile修饰一些变量:易被操纵系统.硬件.多线程修改的变量 #include <stdio.h> int main() { /* 测试1 */ const int b; // 不初始化会报错 // b = 2;

volatile与const综合分析

在C/C++ 编程中,volatile与const关键字一向容易让人困惑,当然,新手可能从来不用,但是 在高质量和稳健的程序中,这两个关键字 是相当重要的. 相比const,volatile关键字的发展(变化)较少,从C到C++的演变中,一直保持着 它的语义,因此,我们先从volatile来了解下,这两个关键字 一.volatile 1.volatile 的基础 认知: volatile 的英文 释义是 容易 挥发的, 作为 关键字,可以 记忆为 它修饰的 变量 是 不稳定的,可能被其他地方的某

C/C++ const变量的修改

C语言中的const是运行时const,编译时只有定义,只用在运行时才会初始化,这也是为什么const不能用来定义数组的原因,并且const的值也是可以动态修改的. C++中的const是编译时const,故能够用来初始化数组,企图修改const的值是未定义的,如果要修改const的值只能改变const变量的声明方式为 const volatile c=10. 测试用例: const int ci=10; int *j =(int *)&ci; *j=100; printf("%d,%d

volatile和const

volatile可理解为"编译器警告指示字" volatile用于告诉编译器必须每次去内存中取变量值 volatile主要修饰可能被多个线程访问的变量 volatile也可以修饰可能被未知因数更改的变量 const和volatile放在一起的意义在于: (1)本程序段中不能对a作修改,任何修改都是非法的,或者至少是粗心,编译器应该报错,防止这种粗心:(2)另一个程序段则完全有可能修改,因此编译器最好不要做太激进的优化. "const"含义是"请做为常量使用

const变量探究

同样的一段代码,在c和c++中的表现却不相同. #include <stdio.h> #include <stdlib.h> int main() { const int i = 1; int *j =(int *) &i; *j = 0; printf("%d,%d\n", i,*j); system("pause"); } 当用c编译器编译运行时,结果是0,0 当用c++编译器编译运行时,结果是1,0 原因:c语言中const变量

volatile与const同时使用应注意的问题(转载)

“volatile”的含义是“请不要做没谱的优化,这个值可能变掉的”,而并非“你可以修改这个值”.因此,它们本来就不是矛盾的 const和volatile放在一起的意义在于: (1)本程序段中不能对a作修改,任何修改都是非法的,或者至少是粗心,编译器应该报错,防止这种粗心: (2)另一个程序段则完全有可能修改,因此编译器最好不要做太激进的优化. “const”含义是“请做为常量使用”,而并非“放心吧,那肯定是个常量”. “volatile”的含义是“请不要做没谱的优化,这个值可能变掉的”,而并非

const变量的修改实践

https://bbs.csdn.net/topics/110049293 #include <iostream> using namespace std; int main(){ cout << "const变量实践:" << endl; // 必须加 volatile才会改变 const volatile int a111 = 1; *((int*)&a111) = 22222; cout<<a111<< endl

const变量初始化问题

在C++中const变量定义时必须进行初始化,否则无法通过编译. 初始化的方式有多种,可以通过字面值对其进行初始化,也可以通过变量对其初始化,或其他方式,只要能给const变量赋初值即可(当然初值应该有其意义). 例: ? 1 2 3 int i = -1; const int ic1 = -1; const int ic2 = i; 不合法情况: const int ic = i; int *const cpi = &ic; 因为const指针cpi指向的不是一个const对象. const变

为什么为 const 变量重新赋值不是个静态错误

const 和 let 的唯一区别就是用 const 声明的变量不能被重新赋值(只读变量),比如像下面这样就会报错: const foo = 1 foo = 2 // TypeError: Assignment to constant variable. 注:本文不会使用“常量”这个术语,因为我觉的这个术语容易有歧义:有些人把数字.字符串等这些不可改变的字面量称为常量,也有人把一些只读属性称为常量,比如 Math.PI,还有人把 ES6 里用 const 声明的变量称为常量.不过一般来说,这点歧