为什么可以对Nvmem做cache,对register不可以?

对Nvmem做一层cache,这样可以减少每次读取Nv bytes时,从总线上read的时间消耗,那么为什么不对register做同样的事情?

register可能是时刻变化的(Volatile),如果做cache,没有机制能保证cache时刻都和register值一致。

volatile 关键字是一种类型修饰符,用它声明的类型变量表示可以被某些编译器未知的因素更改,比如:操作系统、硬件或者其它线程等。遇到这个关键字声明的变量,编译器对访问该变量的代码就不再进行优化,从而可以提供对特殊地址的稳定访问。声明时语法:int volatile vInt; 当要求使用 volatile 声明的变量的值的时候,系统总是重新从它所在的内存读取数据,即使它前面的指令刚刚从该处读取过数据。而且读取的数据立刻被保存。

A volatile specifier is a hint to a compiler that an object may change its value in ways not specified by the language so that aggressive optimizations must be avoided.
https://www.cnblogs.com/yc_sunniwell/archive/2010/07/14/1777432.html

当定义了几个变量:

int i = 10;
int j = i;
int k = i;

如果这些变量都是内存中的变量,这样写是OK的,程序运行过程中i没有改变。但是如果i对应的是register,或者有多个线程同时访问i,这样就是不可靠的。
编译器对i做了对应于i地址的缓存,每次读取j, k都是从缓存中获取值。用volatile可以告诉编译器不要做优化,每次都从i的地址上读取。
http://blog.chinaunix.net/uid-26694208-id-3345118.html

https://liam.page/2018/01/18/volatile-in-C-and-Cpp/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值