计算机组成原理的学习笔记(2)--数据的表示和运算·其一

学习笔记

前言

本文主要是对于b站尚硅谷的计算机组成原理的学习笔记,仅用于学习交流。

正文

1. 浮点数表示

  • 浮点数结构

    • 符号位(1 位):表示数值的正负。

    • 阶码(8 位):表示指数部分,使用偏移量(bias)进行编码,多为 127。

    • 尾数(23 位):表示有效数字部分,隐含前导 1。

  • 小数点位置

    • 通过尾数和阶码共同决定。尾数部分隐含一个 1,小数点在这个数字之后,阶码调整小数点位置。

    • 由于尾数可以表示小数,而小数的n次方不像整型的n次方,小数可以表示的范围会更大,就变得能够表示很多数据了,表示的数据范围也更大了!

  • IEEE 754 标准:浮点数遵循该标准以表示真实世界中的数值,提供有效的数值范围。

2. 移码表示

  • 定义:移码是通过对数值加上一个固定的偏移量(bias),使得浮点数或有符号整数的表示能够规范化,也便于比较。

  • 转换

    • 正数的移码值:实际值 + 偏移量。

    • 负数的移码值:实际值 + 偏移量。

  • 特点:允许负数和正数直接进行比较,无需关注符号。

3. 补码和反码

  • 原码:最基本的表示方式,符号位 + 数值。

  • 反码:负数由原码的符号位不变,其余位取反。

  • 补码:在反码的基础上加 1。补码是计算机中使用的主要数值表示形式。

4. 运算后的符号判断

  • 加法结果判断

    • 使用符号位判断结果是正数还是负数。
  • 溢出

    • 两个同符号数相加,若结果符号位变化则发生溢出。

5. 符号位的影响

  • 进位与符号位:当进行补码的运算的时候,进位不会影响最终结果的符号位,符号位决定结果是否为正数或负数,而符号位之后的不考虑。

7. 整数溢出

  • 整数溢出 :由于补码表示的特性,当超出表示范围时,会出现负数等错误结果,例如,当进行超过这个int类型的运算时,溢出 就会发生。比如说,如果你尝试将2,147,483,647

    二进制中表示为:01111111 11111111 11111111 11111111加上 1, 正常情况下应为 2,147,483,648,但在 int 补码表示中,这是无法表示的。因为溢出,结果会变成:10000000 00000000 00000000 00000000,这对应于 -2,147,483,648。这就是我们常说的爆int,在VS中可以验证这一点,如图所示:

  • 而当在unsigned int 类型中,赋值负数,同时以%u输出,则会将符号位识别为数值,同时输出,这一点也可以在编译器中进行验证。

结语

在学习这个数据的表示的时候,我其实最开始感觉挺无趣的,但是后面发现神奇的可以和我们在编译器里面常见的数据溢出联系起来,就开始感兴趣了,果然计算机很厉害,很多东西都不是无厘头的,有一种理性的美。

相关推荐
桃子叔叔几秒前
CoOp:Visual-Language Model从静态模板到动态学习新范式
人工智能·学习·语言模型
m0_689618283 分钟前
灵感源自锁子甲!“刚柔互锁“ 超结构,让无人机雷达隐身率超98%
学习·无人机
立志成为大牛的小牛23 分钟前
数据结构——五十八、希尔排序(Shell Sort)(王道408)
数据结构·学习·程序人生·考研·算法·排序算法
中屹指纹浏览器25 分钟前
指纹浏览器分布式协同计算技术架构与实现
服务器·网络·经验分享·笔记·媒体
石像鬼₧魂石28 分钟前
渗透测试知识管理模板
linux·学习
代码游侠29 分钟前
学习笔记——文件I/O
linux·数据库·笔记·学习·算法
WYiQIU31 分钟前
突破字节前端2-1⾯试: JS异步编程问题应答范式及进阶(视频教学及完整源码笔记)
开发语言·前端·javascript·vue.js·笔记·面试·github
im_AMBER1 小时前
Canvas架构手记 08 CSS Transform | CSS 显示模型 | React.memo
前端·css·笔记·学习·架构
组合缺一1 小时前
Solon AI 开发学习17 - generate - 使用复杂提示语
java·学习·ai·llm·solon·mcp
心动啊1211 小时前
简单学习下redis
数据库·redis·学习