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语言指针以指向的数据类型长度作自增和自减。理解这一点对于以指针直接操作内存是相当重要的。 函 数 指 针 首 先 要 理 解 以 下 三 个 问 题 : ( 1) C语 言 中 函 数 名 直 接 对 应 于 函 数 生 成 的 指 令 代 码 在 内 存 中 的 地 址 , 因此 函 数 名 可 以 直 接 赋 给 指 向 函 数 的 指 针 ; ( 2) 调 用 函 数 实 际 上 等 同 于 "调 转 指 令 + 参 数 传 递 处 理 + 回 归 位 置 入 栈 ",本 质 上 最 核 心 的 操 作 是 将 函 数 生 成 的 目 标 代 码 的 首 地 址 赋 给 CPU的 PC寄 存 器 ; ( 3) 因 为 函 数 调 用 的 本 质 是 跳 转 到 某 一 个 地 址 单 元 的 code去 执 行 , 所 以 可以 "调 用 "一 个 根 本 就 不 存 在 的 函 数 实 体 , 晕 ? 请 往...