C 语言嵌入式系统编程修炼之三:内存操作
数据指针
在嵌入式系统的编程中,常常要求在特定的内存单元读写内容,汇编有对
应的 MOV 指令,而除 C/C++以外的其它编程语言基本没有直接访问绝对地址
的能力。在嵌入式系统的实际调试中,多借助 C 语言指针所具有的对绝对地址
单元内容的读写能力。以指针直接操作内存多发生在如下几种情况:
(1) 某 I/O 芯片被定位在 CPU 的存储空间而非 I/O 空间,而且寄存器对应
于某特定地址;
(2) 两个 CPU 之间以双端口 RAM 通信,CPU 需要在双端口 RAM 的特定
单元(称为 mail box)书写内容以在对方 CPU 产生中断;
(3) 读取在 ROM 或 FLASH 的特定单元所烧录的汉字和英文字模。
譬如:
unsigned char *p = (unsigned char *)0xF000FF00;
*p=11;
以上程序的意义为在绝对地址 0xF000+0xFF00(80186 使用 16 位段地
址和 16 位偏移地址)写入 11。
在使用绝对地址指针时,要注意指针自增自减操作的结果取决于指针指向
的数据类别。上例中 p++后的结果是 p= 0xF000FF01,若 p 指向 int,即:
int *p = (int *)0xF000FF00;
p++(或++p)的结果等同于:p = p+sizeof(int),而 p--(或--p)的结果
是 p = p-sizeof(int)。
同理,若执行:
long int *p = (long int *)0xF000FF00;
则 p++(或++p)的结果等同于:p = p+sizeof(long int) ,而 p--(或--
p)的结果是 p = p-sizeof(long int)。
记住:CPU 以字节为单位编址,而 C 语言指针以指向的数据类型长度作
自增和自减。理解这一点对于以指针直接操作内存是相当重要的。