【开篇】汇编语言之基础知识篇


📋前言

🏠 个人主页:@聆风吟的个人主页
⏰寄语:少年有梦不应止于心动,更要付诸行动。
☀️欢迎大家关注🔍点赞👍收藏⭐️留言📝
🌈作者留言:文章创作不易,可能会有些地方出现错误,还希望广大读者们能够帮忙指出,让我们大家一起共同进步。



一. ⛳️机器语言

    机器语言是机器指令的集合。机器指令展开来讲就是一台机器可以正确执行的命令。电子计算机的机器指令是一系列二进制的数字。
在这里插入图片描述


    早期计算机就是指可以执行机器指令,进行运算的机器。在我们常用的PC机中,有一个芯片,就是我们常说的CPU(Central Processing Unit,中央处理单元)可以完成前面所说的计算机的功能,但是每一种这样的微处理器(CPU)由于硬件设计和内部结构的不同,就需要用不同的电平脉冲来控制,使它工作。所以每一种微处理器都有自己的机器指令集,也就是机器语言。

    早期的程序设计均使用机器语言。程序员们将用0, 1数字编成的程序代码打在纸带或卡片上,1打孔,0不打孔,再将程序通过纸带机或卡片机输入计算机,进行运算。如下图:
在这里插入图片描述
上面这个非常简单的程序,就可以暴露机器码的晦涩难懂和不易查错。如果要写上一个大的程序,你的内心会如何呢?如果当中有 “1” 写成了 “0”,你又如何修改呢?这时候汇编语言便产生了。



二. ⛳️汇编语言的产生

    汇编语言的主体是汇编指令。汇编指令和机械指令的差别在于指令的表示方法上。汇编指令是机械指令便于记忆的书写格式(即汇编指令是机器指令的助记符)。例如:机器指令 1000100111011000 表示把寄存器 BX 的内容送到 AX 中。汇编指令则写成 mov ax, bx。这样的写法与人类语言接近,便于阅读和记忆。

小知识拓展:
    寄存器:简单的讲就是 CPU 中可以存储数据的器件,一个 CPU 中有多个寄存器。AX 是其中一个寄存器的代号,BX 是另一个寄存器的代号。更多详细内容我们将会下寄存器那张讲解。

    汇编语言出现以后,程序猿都开始用汇编编写成源程序。但是问题又来了,计算机只能识别机器指令,那么如何让计算机执行程序猿用的汇编指令编写的程序呢?这时,就需要一个能够将汇编指令转换成机器指令的翻译程序,这样的程序我们称其为编译器。程序猿用汇编语言编写出源程序,再用汇编编译器将其翻译成机器码,由计算机最终执行。如下图:
在这里插入图片描述



三. ⛳️汇编语言的组成

汇编语言发展至今,有以下 3 类指令组成。

  1. 汇编指令:机器码的助记符,有对应的机器码;
  2. 伪指令:没有对应的机器码,有编译器执行,计算机并不执行;
  3. 其他符号:如+-*/ 等,由编译器识别,没有对应的机器码。

汇编语言的核心是汇编指令,它决定了汇编语言的特性。



四. ⛳️存储器

     CPU 是计算机的核心部件,它控制整个计算机的运作并进行运算。要想让一个 CPU 工作,就必须向它提供指令和数据。指令和数据在存储器中存放,也就是平时所说的内存。

  • 在一台PC机中内存的作用仅次于CPU。离开了内存,性能再好的CPU也无法工作。
  • 磁盘不同于内存,磁盘上的数据或程序如果不读到内存中,就无法被CPU使用。


五. ⛳️指令和数据

     指令和数据是应用上的概念。在内存或磁盘上,指令和数据没有任何区别,都是二进制信息。CPU 在工作的时候把有的信息看作指令,有的信息看作数据,为同样的信息赋予不同的意义。例如:内存中的二进制信息 1000100111011000,计算机可以把它看作大小为 89D8H 的数据来处理,也可以将其看作指令 mov ax, bx 来执行。
在这里插入图片描述



六. ⛳️存储单元

存储单元被划分成若干存储单元,每个存储单元从 0 开始顺序编号。例如一个存储器有 128 个存储单元,编号从 0 ~ 127,如下图:
在这里插入图片描述
     我们知道电子计算机中的最小单元是 bit(音译为比特),也就是一个二进制位。8 个bit 组成一个 Byte, 也就是通常讲的一个字节。微型机存储器的存储单元可以存储一个 Byte,即 8 个二级制位。一个存储器有 128 个存储单元,它可以存储 128 个Byte。

对于大容量的存储器一般还用以下单位来计量容量(以下用 B 来代表 Byte):

单位换算关系
千字节(KB)1 KB = 1024 B = 2^10 B
兆字节(MB)1 MB = 1024 KB = 2^20 B
吉字节(GB)1 GB = 1024 MB = 2^30 B
太字节(TB)1 TB = 1024 GB = 2^14 B


七. ⛳️CPU 对存储器的读写

CPU 想要进行数据的读写,必须和外部器件(标准的说法是芯片)进行三类信息的交互:

  • 存储单元的地址(地址信息)
  • 器件的选择,读或写命令(控制信息)
  • 读或写的数据(数据信息)

    那么 CPU 是通过什么将地址、数据和控制性信息传到存储芯片中的呢?电子计算机能处理、传输的信息都是电信号,电信号当然要用导线传送。在计算机中专门有连接 CPU 和其他芯片的导线,通常称为总线。总线分类:

  1. 从物理上来讲:就是一根根导线集合;
  2. 从逻辑上又可以划分为:地址总线、控制总线和数据总线。
    在这里插入图片描述

7.1 地址总线

    CPU 是通过地址总线来指定存储器单元的。可见地址总线上能传送多少个不同的信息,CPU 就可以对多少存储单元进行寻址。那地址总线如何发送信息的呢?
在这里插入图片描述

重点:一个CPU有 N 根地址总线,则可以说这个CPU的地址总线的宽度为 N。这样的CPU最多可以寻找 2^N 个内存单元。


7.2 数据总线

    CPU 与内存或其它器件之间的数据传送是通过数据总线来进行的。数据总线的宽度数据总线的宽度决定了 CPU 和外界的数据传送速度。例如:8根数据总线一次可以传送一个8位的二进制数据(即一个字节)。16根数据总线一次可以传送两个字节。
在这里插入图片描述

7.3 控制总线

    CPU 对外部器件的控制是通过控制总线来进行的。在这里控制总线是个总称,控制总线是一些不同控制的线的集合。有多少根控制总线,就意味着CPU提供了对外部器件的多少控制。所以,控制总线的宽度决定了 CPU 对外部器件的控制能力



📝总结

本文回顾:

  1. 汇编指令是机器指令的助记符,同机器指令一 一对应;
  2. 每一种CPU都有自己的汇编指令集;
  3. CPU可以直接使用的信息在存储器中存放;
  4. 在存储器中的指令和数据没有任何区别,都是二进制信息;
  5. 存储单元从零开始顺序编号;
  6. 一个存储单元可以存储8个bit,即8个二进制位;
  7. 1Byte = 8bit、1KB = 1024B、1MB = 1024KB、1GB = 1024MB、1TB = 1024GB
  8. 地址总线的宽度决定了CPU的寻址能力;
  9. 数据总线的宽度决定了CPU与其他器件进行数据传送时的一次数据传送量;
  10. 控制总线的宽度决定了CPU对系统中其他器件的控制能力。

    今天的内容就到这里了,你们都学会了吗?如果还有疑问的话请在评论区里多多提问,大家可以一起帮你解决,让我们共同进步。创作不易,如果对你有用的的话点个赞支持下作者,你们的支持是作者创作最大的动力。关注我不迷路。


文献参考:
《汇编语言》由郑爽老师著作。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

聆风吟_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值