《系统级程序设计》——重点&汇编上手

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

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)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值