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



    📋前言

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



    一. ⛳️机器语言

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


        早期计算机就是指可以执行机器指令,进行运算的机器。在我们常用的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对系统中其他器件的控制能力。

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


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

  • 相关阅读:
    【乱码】记一次C#调用Java乱码
    实战:3D目标检测与跟踪PointPillar+CenterPoint+SimpleTrack(论文+代码 上篇)
    Linux学习笔记
    基础到高级涵盖11个技术,Alibaba最新出品711页Java面试神册真香
    决策树分男女性别
    Java ArrayList与顺序表
    力扣-383.赎金信
    SpringBoot借助hutool生成图片二维码
    【1】前端学习笔记
    解决gif 透明度问题
  • 原文地址:https://blog.csdn.net/2301_80026901/article/details/133830812