原码
我们知道,数值具有正负两种符号,但是计算机仅由0和1两种状态构建而成,因此并没有专门用来表示正负号的原生方式,我们凭直觉设计就是挪用其中的一位来表示正负号,简单起见,如果我们用3位表达一个数值,这样的编码系统实际上能够表达的范围将会是: -(2^2 - 1) = -3, -2, -1, -0, +0, +1, +2, +(2^2 - 1) = +3
补码
字节序(大小端)
大端:高位在低地址,地位在高地址 小段:高位在高地址,地位在低地址 验证程序:
// Demo:观察字节序的一个简单例子
#include <stdio.h>
#include <limits.h>
typedef unsigned char *pointer;
void show_bytes(pointer start, size_t len){
size_t i;
for (i = 0; i < len; i++)
printf("%p\t0x%.2x\n",start+i, start[i]);
printf("\n");
}
int main(){
int a = 0x01234567;
show_bytes((pointer) &a, sizeof(int));
}
输出结果: // 输出结果(Linux x86-64)
$ gcc -o chp2 chp2.c ;
$ ./chp2
0x7ffc837a0b3c 0x67
0x7ffc837a0b3d 0x45
0x7ffc837a0b3e 0x23
0x7ffc837a0b3f 0x01
文档信息
- 本文作者:stepbystep
- 本文链接:https://isanthree.github.io/2020/07/10/csapp/
- 版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证)