稍有些英语常识的人都会知道,如果单靠字面意思来理解俚语,那是很难猜到它的正确含义的。在计算机里,对于地址的描述,很少用“大”和“小”来形容;对应地,用的更多的是“高”和“低”;很不幸地,这对术语直接按字面翻译过来就成了“大端”和“小端”,让人产生迷惑也不是很奇怪的事了。
既然这样,我们就用“高尾端”来代替“大端”,用“低尾端”来代替“小端”。
在裘宗燕翻译的《程序设计实践》里,这对术语并没有翻译为“大端”和小端,而是“高尾端”和“低尾端”,这就好理解了:如果把一个数看成一个字符串,比如11223344看成”11223344”,末尾是个’\0’,’11’到’44’个占用一个存储单元,那么它的尾端很显然是44,前面的高还是低就表示尾端放在高地址还是低地址,它在内存中的放法非常直观,如下图:
最后在附上一段自己写的判断 机器是“高尾端”还是“低尾端”的C代码
#include<cstdio>
void foo(int *p){
printf("%x||",*p);
}
int main(){
char c[] = {0x12,0x34,0x56,0x78};
for(int i = 0;i != 4;++i)
foo((int*)&c[i]);
return 0;
}
在笔者的电脑上,输出结果如图:
看到第一行是:78563412.
即尾端(78)放在内存的低位,说明机器采用的是“低尾端”。
事实上,大部分采用intel的计算机都是“低尾端”,不过面试的时候可不一定
转自:http://www.cnblogs.com/wuyuegb2312/archive/2013/06/08/3126510.html