csapp2e 读书笔记
来源:互联网 发布:德雷克斯勒生涯数据 编辑:程序博客网 时间:2024/05/29 20:00
CSAPP 读书笔记
Table of Contents
- 1 第二章 信息的处理和表示
- 1.1 C语言中的位级表示
- 1.1.1 交换两个值
- 1.1.2 习题2.12
- 1.1.3 习题2.13
- 1.2 C语言中的移位运算
- 1.3 整数表示
- 1.3.1 有符号数和无符号数之间的转换
- 1.3.2 习题2.21
- 1.3.3 扩展一个数字的位表示
- 1.3.4 习题2.27
- 1.3.5 习题2.30
- 1.3.6 习题2.32
- 1.3.7 补码非的位级表示
- 1.3.8 习题2.34
- 1.1 C语言中的位级表示
1 第二章 信息的处理和表示
1.1 C语言中的位级表示
1.1.1 交换两个值
void inplace_swap(int *x,int *y){ *x = *x ^ *y; *y = *x ^ *y; *x = *x ^ *y;}
这种交换方式并没有性能上的优势,仅仅是个智力游戏
网络资料 :异或运算的作用
- 0异或任何数=任何数
- 1异或任何数-任何数取反
- 任何数异或自己=把自己置0
按位异或的几个常见用途:
- 使某些特定的位翻转 例如对数10100001的第2位和第3位翻转,则可以将该数与00000110进行按位异或运算。
10100001^00000110 = 10100111
- 在汇编语言中经常用于将变量置零: xor a,a
- 快速判断两个值是否相等 举例1: 判断两个整数a,b是否相等,则可通过下列语句实现: return ((a ^ b) == 0)
1.1.2 习题2.12
1.1.3 习题2.13
设bic(x,m)为在m为1的每个位置,将x对应的位设置为0,则bic(x,m) == x&~m
x^y=(x&~y)|(~x&y)
1.2 C语言中的移位运算
- 逻辑右移
- 在左端补k个0
- 算术右移
- 在左端补k个最高有效位的值
- 移动k位,这里k很大
- C语言标准很小心地规避了说明在这种情况下该如何做。实际上位移量就是通过计算k mod w得到的,例如w=32,即32位机,右移36位即4位,左移32位即0位,右移40位即8位
1.3 整数表示
补码的范围是不对称的:|TMin|=|TMax|+1,也就是说TMin没有与之对应的正数。之所有有这样的不对称性,是因为一半的位模式(符号位设置为1的数)表示负数,而一半的数(符号位设置为0的数)表示非负数。因为0是非负数,也就意味着能表示的正数比负数少一个。第二,最大的无符号数值刚好比补码的最大值的两倍大一点:UMaxw=2TMaxw+1。补码表示中所有表示负数的位模式在无符号表示中都变成了正数。注意-1和UMax有同样的为表示——一个全1的串。数值0在两种表示中都是全0的串。
1.3.1 有符号数和无符号数之间的转换
强制类型转换的结果保持位值不变,知识改变了解释这些位的方式。-12345的16位补码表示与53191的16位无符号表示是完全一样的。
在C语言中,当执行一个运算时,如果它的一个运算数是有符号的而另一个是无符号的,那么C语言会隐式地将有符号参数强制转换为无符号数,并假设这两个数都是非负的,来执行这个运算。
这种方法对于标准的算术运算来说并无多大差异,但是对于像<和>这样的关系运算符来说,会导致非直观的结果。
1.3.2 习题2.21
1.3.3 扩展一个数字的位表示
将一个无符号数转换为一个更大的数据类型,我们只需要在表示的开头添加0,这种运算称为 零扩展
。将一个补码数字转换为一个更大的数据类型可以执行符号扩展
,规则是在表示中添加最高的有效位的值的副本。设short x=-12345,把short转换为unsigned时,我们先要改变大小,之后再完成从有符号到无符号的转换,也就是说(unsigned)x等价于(unsigned)(int)sx,求值得到4294954951,而不等价于(unsigned)(unsigned short)x,后者求值得到53191。事实上,这个规则是C语言标准要求的。
1.3.4 习题2.27
这个函数是对确定无符号加法是否溢出的规则的直接实现。如果参数x和y相加不会产生溢出,这个函数就返回1。
int uadd_ok(unsigned x,unsigned y){ unsigned sum = x+y; return sum >= x;}
1.3.5 习题2.30
这个函数是对确定补码加法是否溢出的规则的直接实现
int tadd_ok(int x,int y){ int sum = x+y; int neg_over = x < 0 && y <0 && sum >= 0; int pos_over = x >= 0 && y>= 0 && sum < 0; return !neg_over && !pos_over;}
1.3.6 习题2.32
补码减法溢出
int tsub_ok(int x,int y){ int sub = x - y; return (x >= y)?(sub >= 0):(sub < 0);}
1.3.7 补码非的位级表示
对每一位求补,再对结果+1,在C语言中,我们可以确定对于任意整数值x,计算表达式-x和~x+1得到的结果完全一样。
1.3.8 习题2.34
Date: 2014-02-26T10:21+0800
Org version 7.9.3f withEmacs version 24
Validate XHTML 1.0- csapp2e 读书笔记
- csapp2e家庭作业2.58
- csapp2e 家庭作业2.59
- csapp2e 家庭作业2.60
- csapp2e 家庭作业2.61
- csapp2e 家庭作业2.62
- csapp2e 家庭作业2.63
- csapp2e 家庭作业2.64
- csapp2e 家庭作业2.65
- csapp2e 家庭作业 2.66
- csapp2e 家庭作业 2.67
- csapp2e 家庭作业 2.69
- csapp2e 家庭作业 2.70
- csapp2e 家庭作业 2.71
- csapp2e 家庭作业 2.72
- csapp2e 家庭作业 2.73
- csapp2e 家庭作业 2.74
- csapp2e 家庭作业 2.75
- http://www.virten.net/2014/02/solve-android-x86-no-network-problems-in-vmware-workstation/
- 2013年终工作总结及工作计划
- 【高薪就业必备05】java中构造器Constructor是否可被override?
- 分萨芬
- android项目命名规范
- csapp2e 读书笔记
- POJ 1182 食物链
- NYOJ 67 三角形面积
- 优秀C/C++源代码网站
- 用户不在sudoers文件中的解决方法 .
- 成长的路上每一步都需要自己去用心体会!
- jquery 选取方法 笔记
- 最短路SPFA算法
- 比特币引发的反思