请教关于总线错误(Bus error) 和 定位处理问题.

2016-12-30 19:45:04来源:作者:人点击

第七城市

在编制一和运行一个程序的时候, 人们可能会遇到下面的信息:"Bus error(core dumped);. 当出现这种信息的时候,则表示在SPARC等RISC类型的CPU中发生了"违反定位访问"的情况.例如,读者可以阅读下面的程序.

#include < string.h >#include < stdio.h >void main() {    char buf[256];    int * x;    x = (int * ) & buf[1]; * x = 68000;    printf("*x = %d/n", *x);}

在这段程序中,能够确保256byte的存储器区域,其中能够存储68000的整数值.但是,这样也会发

生前面所讲的地址问题.在上述的情况下,数组buf的存储区域从4的整数倍开始.在该数组的第二个

位置(即奇数地址单元)中赋予了数据类型为int的值.在RISC类型的CPU中,数据类型int值不能存储

在4的整数倍地址中.因此,在将要对变量x赋值68000的时候,CPU不能够继续执行这个程序,则出现

Bus error这个信息,然后终止该程序的运行.

但是,在Pentinm(奔腾)系列的CPU中,则不会产生Bus error这个信息.这是因为采用了Pentinm

系列的80386的流程的RISC类型的CPU,提高了CPU的处理效率,或电路进行了简单化处理,从8位开始

就使用了重视移植性的体系结构.

在上述中,我看得不是很明白.请高人详细地解说一下.

其中最不能理解的是:

1. "数组buf的存储区域从4的整数倍开始" 为什么?

2. "在RISC类型的CPU中,数据类型int值不能存储在4的整数倍地址中" 为什么?

3. "x = (int *) & buf[1];" , 这条语句我知道是进行强制转换,可是char类型的&buf[1]不是

只有8bit吗?它怎么可以转换成具有32bit的x呢?

4. "x = (int *) & buf[1];" , 这条语句到底是怎么实现的?或者说我该怎么去理解它?

最佳答案

1 在SPARC等RISC类型的CPU中,int型数据在内存中4字对齐,char buf[256]s虽然是char型,但为256个(4的倍数),所以编译器也使其4字对齐,及其内存开始地址必为4的整数倍,例如0x1000;

2。 该句表述错误,实际应为“在RISC类型的CPU中,数据类型int值只能存储在4的整数倍地址中”

3 此处强制类型转换的是指针而非char型变量,指针指向的内存只不过是一些数据,你可以认为这些数据是任意类型,char、int 、float、double甚至结构

4 假设buf的开始地址为0x1000,则这句将0x1001~0x1004的内容拷贝给x(x为int型),如前所述,int型数据地址必须为4的整数倍,此处0x1001不满足该条件,故会引起CPU内部总线错误

第七城市

最新文章

123

最新摄影

微信扫一扫

第七城市微信公众平台