深入理解——第二章学习总结

第一节 信息存储

一、十六进制表示法

0x0X开头的数字常量为十六进制

二进制-十六进制相互转换

※一种特殊情况

要表示的数字常量x=2的n次方时,n=i+4j,且0≤i≤3时,开头的十六进制数字为1(i=0)、2(i=1)、4(i=2)、8(i=3),后面跟随着j个十六进制的0。这里的j是代表着每四位二进制位对应的十六进制位,而i的范围是因为十六进制中每一位的范围是0-F,最多能容纳到8。

二、寻址和字节顺序

小端法和大端法

  • 小端法:最低有效字节在前面——“高对高,低对低”
  • 大端法:最高有效字节在前面

以0x01234567为例:

最高有效位在最前,所以为01 23 45 67
小端法:
最低有效位在最前,所以为67 45 23 01

三、位运算

常用运算符号:
与: &
或: |
非: ~
异或:^
  • 位运算:位向量按位进行逻辑运算,结果仍是位向量(区别于逻辑运算)

四、逻辑运算

逻辑运算符
与:&&
或:||
非:! 
  • 逻辑运算的计算结果:

所有非零参数都代表TRUE,0参数代表FALSE

逻辑运算和位运算的区别

1.只有当参数被限制为0或1时,逻辑运算才与按位运算有相同的行为。
2.如果对第一个参数求值就能确定表达式的结果,逻辑运算符就不会对后面的参数求值。

五、移位运算

右移分为逻辑右移算术右移

  • 逻辑右移:

    在左端补k个0,多用于无符号数移位运算

  • 算术右移:

    在左端补k个最高有效位的值,多用于有符号数移位运算。

第二节 整数表示

一、补码编码

  • 补码的最高位是表示符号位,解释为负权,“权重”为-2的(w-1)次方,即无符号表示中的权重的负数。符号位为1,表示值为负,符号位为0,表示值为非负
  • 补码的范围:-2^(w-1)~2^(w-1)-1,即|TMin|=|TMax|+1
  • 无符号数编码(U)和补码(T):UMax = 2 TMax + 1

二、有符号数和无符号数的转换

有符号数换为无符号数
  • 非负数——保持不变
  • 负数——加上2^w,转换成大正数
    无符号数换为有符号数

    以2的w-1次方为界限:

  • 小于它——保持不变
  • 大于它——减去2^w,转换为负数值

三、扩展

零扩展

多用于无符号数转换为一个更大的数据类型。

只需在开头加上0即可。

符号扩展

多用于补码数字转换

最高有效位是什么,就添加什么。

四、截断

将一个w位的数截断为k位数字时,就会丢弃高w-k位。

对于无符号数来说,就相当于 mod 2的k次幂

对于有符号数来说,先按照无符号数截断,然后再转化为有符号数

第三节 整数运算

整数运算即mod 2^w。

1.补码的非运算

对于范围在[-2^(w-1),2^(w-1))中的x,补码的非运算有如下两种情况:

x=-2^(w-1)时,为-2^(w-1)

x>-2^(w-1)时,为-x

2.求位级补码非
  • 对每一位求补,再对结果+1
  • 设k为最右面的1的位置,将k左边的所有位取反。

乘以常数

1.常数为2的k次幂的时候

直接左移k位即可。

2.常数不是2的整数次幂的时候

将常数C表示为2的几个整数次幂的和,结合移位运算和加法运算。

除以2的k次幂

1.无符号数——逻辑右移

无符号数除以2的k次幂,就等同于对其逻辑右移k位。

2.补码——算术右移

  • x≥0时,除以2的k次幂等价于将x算术右移k位
  • x<0时,先将x加上(2^k)-1,再算术右移k位

第四节 浮点数

一、二进制小数

小数的二进制表示法只能表示那些能够被写成x X (2^y)的数,其他的值只能近似的表示。

权重

以小数点为界:

左边第i位,权重为2的i次幂
右边第i位,权重为1/2的i次幂

二、IEEE浮点表示

IEEE浮点标准:

用V=(-1)^s X 2^E X M 来表示一个数:
符号:s决定这个数是正还是负。0的符号位特殊情况处理。
阶码:E对浮点数加权,权重是2的E次幂(可能为负数)
尾数:M是一个二进制小数,范围为1~2-ε或者0~1-ε(ε=1/2的n次幂)

编码规则:

单独符号位s编码符号s,占1位
k位的阶码字段exp编码阶码E
n位小数字段frac编码尾数M(同时需要依赖阶码字段的值是否为0)

两种精度

  • 单精度(float),k=8位,n=23位,一共32位;
  • 双精度(double),k=11位,n=52位,一共64位。

三种被编码情况

  • 规格化的
  • 非规格化的
  • 特殊值

三、舍入

1.向偶舍入

即:将数字向上或向下舍入,是的结果的最低有效数字为偶数。

能用于二进制小数。

2.向零舍入

把整数向下舍入,负数向上舍入。

3.向下舍入

正数和负数都向下舍入。

4.向上舍入

正数和负数都向上舍入。

向偶舍入可以得到最接近的匹配,其余三种可用于计算上界和下界

四、浮点运算

1.浮点加法

  • 浮点加法是可交换的
  • 浮点加法不具结合性
  • 大多数值的浮点加法都有逆元,除了无穷和NaN。
  • 浮点加法满足单调性

2.浮点乘法

  • 浮点乘法是可交换的
  • 浮点乘法不具有结核性
  • 浮点乘法的单位元为1.0
  • 浮点乘法在加法上不具备分配性
  • 在一定条件下满足单调性

所遇到的问题:

1.p35中的题2.13

在做这道题时,第一问很好理解,但是第二问我怎么都做不出来,后来查看答案后也不是很好理解。后来我用了数电上的方法计算,我发现bis 函数即为x&y,而bic函数即为x&~y,这样就很好理解了。

2.p51中的题2.23

在进行有符号的算术右移时,我忽略了十六进制到二进制的转换,题中有句提示说:记住十六进制数字8到F的最高有效位为1。这样我们计算时,只要在右移时注意大于7的数字,即在前面添加二进制的1,换为十六进制即为F。

3.p52中的题2.24

开始时我并不能很好的理解截断的意思,做完这道题后我发现对于k位的截断数值来说,它的范围在-2^(k-1)~2^(k-1)-1之间,而且要注意补码的截断值仍然用补码来表示。

时间: 2024-12-17 12:00:54

深入理解——第二章学习总结的相关文章

20172304 2018-2019《java软件结构与数据结构》 第一章 第二章学习总结

20172304 2018-2019<java软件结构与数据结构> 第一章 第二章学习总结 教材学习内容总结 第一章 概述 1.1软件质量: 高质量软件的几个特征: 正确性:软件在多大程度上满足其特定需求 可靠性:软件故障发生频率和危险程度 健壮性:出错情况下可以得到恰当处理的程度 可用性:用户学习和执行任务的难易程度 可维护性:对软件进行修改的难易程度 可重用性:软件组件可重用于其他软件系统开发的难易程度 可移植性:软件组件可以在多个计算机环境下使用的难易程度 运行效率:在不浪费资源的情况下

Python核心编程第三版第二章学习笔记

第二章 网络编程 1.学习笔记 2.课后习题 答案是按照自己理解和查阅资料来的,不保证正确性.如由错误欢迎指出,谢谢 1. 套接字:A network socket is an endpoint of a connection across a computer network,Sockets are often represented internally as simple integers, which identify which connection to use. 套接字是网络通信的

第二章学习小结

数据结构第二章的学习结束了,了解了顺序表,单链表的建立,插入,删除,查找的算法,以及对它们时间复杂度,空间复杂度的分析.学会区分头指针,头结点和首元结点. 前插法,后插法创建单链表,相比之下,我觉得后插法比较好理解.双向链表就是那个表示被处理结点的前驱的后继(p->prior->next),结点的后继的前驱(p->next->prior)要区分开. 作业,说实话,一开始的时候,我真的很懵,书上的算法描述,我可以看的很明白,同时也感到很奇怪,甚至还一度认为那是可以敲上电脑进行编译运行

第二章学习心得

分治法把大问题分解成很多个同类的小问题,是一个很实用的方法,在解决一些问题的时候非常实用. 结合对时间复杂度的考虑来决定是否该使用分治算法,如果时间复杂度太大则规避使用此方法,而不是盲目使用. 然后这次第二章的练习,比如二分搜索和归并的使用,提高了我对此类算法的熟练程度,在以后的一些排序当中可以适当使用. 对此次结对编程的总结:默契还是不太足够,或许是我理解能力和思维模式稍显逊色吧.以后要多多交流,向队友学习新的思路和解题方法,我也会提出自己的见解加以完善. 原文地址:https://www.c

Machine Learning In Action 第二章学习笔记: kNN算法

本文主要记录<Machine Learning In Action>中第二章的内容.书中以两个具体实例来介绍kNN(k nearest neighbors),分别是: 约会对象预测 手写数字识别 通过“约会对象”功能,基本能够了解到kNN算法的工作原理.“手写数字识别”与“约会对象预测”使用完全一样的算法代码,仅仅是数据集有变化. 约会对象预测 1 约会对象预测功能需求 主人公“张三”喜欢结交新朋友.“系统A”上面注册了很多类似于“张三”的用户,大家都想结交心朋友.“张三”最开始通过自己筛选的

201671010105 2016-2017-2《Java程序设计》第一、第二章学习心得

我们大一的时候学习的是C语言程序设计,C语言是面向程序的,而老师也说过我们后面会学习一种面向对象的程序设计语言--Java程序设计,而在二年级开学第一周,我们第一次真正意义上接触到了它. 令人意外的是和往常老师讲学生听不同,这一周我们对Java程序设计第一.第二章的学习完全是自主的,通过一周对Java第一.第二章的学习,心得体会如下: 第一章 Java程序设计概述 1.通过对第一章的学习,对Java有了比较深入的了解,Java和C一样,是一种语言,但它又不止是一种语言,它是一个完整的程序设计平台

《HeadFirst Python》第二章学习笔记

现在,请跟着舍得的脚步,打开<HeadFirst Python>第二章. 一章的内容其实没有多少,多练习几次就能掌握一个大概了! <HeadFirst Python>的第二章设计得很有意思.它直接从制作一个模块入手,顺带讲了模块的导入,传统的书可不会这么搞. 不过书中关于编辑器的观点略显陈旧. 最好的编辑器是什么? 别用书中推荐的Python自带IDLE,在现阶段,请使用Jupyter Notebook来进行各项练习. 等学完这本书后,你可以选择PyCharm/Eric6/Wing

《Unity3D 游戏开发经典教程》 第一第二章学习

花时间看了第一和第二章的内容,将书上的例子做成了个一个简单的游戏Protype. git 源码地址:https://github.com/crj8812/Unity3D            UGDE 蓝色为子弹,红色为被击垮的墙壁

第二章学习总结

本章我学习了有关线性表的数据结构:它可以用顺序存取结构来实现也可以用链式存取结构来实现,具体到C++编程语言里就是数组和链表. 它们各有优缺点: 顺序存取结构:逻辑上相连,物理上也相连.优点就是随机存取.查找表中元素十分方便,但缺点就是插入或者删除操作需要移动大量的元素. 链式存储结构:逻辑上相连但物理上不完全相连.优缺点与顺序存储结构刚好相反. 接下来我想起讲讲自己在学习本章知识的感想. 第一,不能单一参考一种资料,理解一个抽象的东西最好的方法,就是参考不同的书本,看不同版本的定义.一开始,我