对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