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


在编制一和运行一个程序的时候, 人们可能会遇到下面的信息:"Bus error(core dumped);. 当出现这种信息的时候,则表示在SPARC等RISC类型的CPU中发生了"违反定位访问"的情况.例如,读者可以阅读下面的程序.
#include
#include
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];" , 这条语句到底是怎么实现的?或者说我该怎么去理解它??
收起
lcy7618291  |  浏览 8304 次
推荐于2016-09-20 16:31:19 最佳答案
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内部总线错误

你可能感兴趣的:(C++,linux,kernel)