1.这是我根据我的印象抽取的重点,希望不要奶死了。
2.里面有看汇编代码的迅速上手,如果要熟练,请一定要完成几个书上的汇编逆向出代码的题目。
当表达式既有signed又有unsigned的时候,自动转换为unsigned
数的补码表示:最高位为符号位,代表的值不再是2^k 而是 -2^k,但是其余位不变。
eg.
[1001] = -8 + 0 + 0 + 1 = -7;负数补码算数右移,加偏置量2^n-1(n为右移位数)
eg.
[1001] >> 2 = [1110] = -8 + 4 + 2 + 0 = -2;
而 -7 / 4 = -1;❌
所以要加偏置量2^2 - 1 = 3 = [0011];
则[1001] + [0011] = [1100];
[1100] >> 2 = [1111] = -8 + 4 + 2 + 1 = -1;✔️二进制小数:只能表示x/(2^k)
eg.
[0.101] = (4 + 1) / (2 ^ 3) = 5 / 8;浮点数:非规格化的作用
1、提供了一种表示0的方法,因为规格化数小数位>=0。
eg.-0.0 & 0.0,除了符号位为1 & 0 其余全为0
2.提供一种叫逐渐溢出的属性,即0.0周围的小数都分布均匀地接近于0浮点数:偏置量bias = 2^(k - 1)-1 ;(k为浮点数指数位位数)
浮点数:非规格化数的偏置为什么为1-bias,而不是bias
因为规格化数小数位隐含第一位为1,而非规格化数没有。
为了实现最大非规格化数与最小规格化数之间的平滑过度,所以为1-bias浮点数:特殊值
if(指数位全为1)
{
if(若小数位全为0)
表

本文介绍了系统级程序设计的重点,包括汇编语言的学习,特别是在处理混合类型表达式时的规则,以及补码表示和算术右移的理解。强调了通过实践书中的汇编逆向题目来提升技能。还涉及浮点数的非规格化表示、特殊值处理和浮点数的偏置量计算。同时讲解了寄存器、指令系统、指针的使用和复杂取地址方式。最后提到了条件跳转、条件传送指令、数组和结构体的存储以及缓冲区溢出攻击及其防范机制。
最低0.47元/天 解锁文章
4万+

被折叠的 条评论
为什么被折叠?



