深入理解操作系统(CSAPP)第 02 章:信息的表示和处理

内容纲要

备链:https://isanthree.github.io/2020/07/10/csapp/

原码

我们知道,数值具有正负两种符号,但是计算机仅由0和1两种状态构建而成,因此并没有专门用来表示正负号的原生方式,我们凭直觉设计就是挪用其中的一位来表示正负号,简单起见,如果我们用3位表达一个数值,这样的编码系统实际上能够表达的范围将会是:
-(2^2 - 1) = -3, -2, -1, -0, +0, +1, +2, +(2^2 - 1) = +3

image-1700281854519.png

补码

image-1700281884684.png

字节序(大小端)

image-1700281920133.png

大端:高位在低地址,地位在高地址
小段:高位在高地址,地位在低地址
验证程序:

// 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 
点赞

发表回复

电子邮件地址不会被公开。必填项已用 * 标注