热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【汇编语言01】第1章基础知识

目录1前言1.1语言发展历程1.2特点1.3为什么要学汇编语言1.4学习重点2汇编语言基础概念2.1汇编语言的组成2.2汇编指令2.3指令和数据2.4存储器2.4.1存储器简介2.

目录

  • 1 前言
    • 1.1 语言发展历程
    • 1.2 特点
    • 1.3 为什么要学汇编语言
    • 1.4 学习重点
  • 2 汇编语言基础概念
    • 2.1 汇编语言的组成
    • 2.2 汇编指令
    • 2.3 指令和数据
    • 2.4 存储器
      • 2.4.1 存储器简介
      • 2.4.2 存储单元
      • 2.4.3 分类
      • 2.4.4 各类存储器的逻辑连接
    • 2.5 CPU对存储器的读写
    • 2.6 总线
      • 2.6.1 总线概述
      • 2.6.2 地址总线
      • 2.6.3 数据总线
      • 2.6.4控制总线
    • 2.7 主板
    • 2.8 接口卡
    • 2.9 内存地址空间
  • 3 小结
  • 参考文献


1 前言

1.1 语言发展历程


  1. 历程:机器语言→汇编语言→高级语言
  2. 机器语言:人们为了去控制计算机完成自己的任务或者项目,只能去编写“0”、“ 1”这样的二进制数字串去控制电脑,其实就是控制计算机硬件的高低电平或通路开路,这种语言就是机器语言。
  3. 汇编语言:机器语言作为一种编程语言, 灵活性、可阅读性都很差,为了减轻机器语言带给软件工程师的不适应,人们对机器语言进行了升级和改进:用一些容易理解和记忆的缩写单词来代替一些特定的指令。
  4. 高级语言:为解决程序的可移植性,需要设计一个能够不依赖于计算机硬件,能够在不同机器上运行的程序。这样可以免去很多编程的重复过程,提高效率,同时这种语言又要接近于数学语言或人的自然语言。

1.2 特点


  1. 优点
    (1)可以轻松的读取存储器状态以及硬件I/O接口情况
    (2)编写的代码因为少了很多编译的环节,可以能够准确的被执行
    (3)作为一种低级语言,可扩展性很高
  2. 缺点
    (1)因为代码非常单调,特殊指令字符很少,所以造成了代码的冗长以及编写的困难
    (2)因为汇编仍然需要自己去调用存储器存储数据,很容易出现BUG,而且调试起来也不容易
    (3)就算完成了一个程序,后期维护时候也需要耗费大量的时间。
    (4)因为机器的特殊性造成了代码兼容性差的缺陷。

1.3 为什么要学汇编语言

汇编语言是培养学生理解硬件资源的语言,是学习和理解其他高级程序设计语言的基础,是计算机组成原理、接口与通信技术、计算机控制技术和数据采集等许多专业课的前导课程,是必要的基础知识,起着承上启下的作用。

1.4 学习重点

研究重点放在如何利用硬件系统的编程结构和指令集有效灵活的控制系统进行工作。

2 汇编语言基础概念

本章节内容主要是了解基本概念,更多知识点后续用到的地方再做补充。

2.1 汇编语言的组成


  1. 汇编指令(机器码的助记符):汇编语言的核心是汇编指令,它决定了汇编语言的特性。
  2. 伪指令 (由编译器执行):没有对应的机器指令,所起的作用主要是对汇编过程进行控制。
  3. 其它符号(由编译器识别):加减乘除等符号。

2.2 汇编指令


  1. 汇编语言的主体是汇编指令,汇编指令是机器指令的助记符。
  2. 汇编指令和机器指令的差别在于指令的表示方法上,汇编指令是机器指令便于记忆的书写格式。
  3. 例子:
    要实现的操作:寄存器BX的内容送到AX中
    机器指令: 1000100111011000
    汇编指令:MOV AX,BX
  4. 寄存器:简单的讲是CPU中可以存储数据的器件,一个CPU中有多个寄存器。

2.3 指令和数据


  1. 指令和数据是应用上的概念。在内存或磁盘上,指令和数据没有任何区别,都是二进制信息,具体是当做指令或者数据,是由程序来决定的。
  2. 例子:
    二进制数据:1000100111011000
    视为数据:89D8H(H表示十六进制)
    视为指令:MOV AX,BX

2.4 存储器


2.4.1 存储器简介


  1. 存储器的作用:
    CPU 是计算机的核心部件.它控制整个计算机的运作并进行运算,要想让一个CPU 工作,就必须向它提供指令和数据。指令和数据在存储器中存放,也就是平时所说的内存
  2. 存储器的地位:
    在一台PC机中内存的作用仅次于CPU。离开了内存,性能再好的CPU也无法工作。
  3. 存储器与磁盘:
    磁盘不同于内存,磁盘上的数据或程序如果不读到内存中,就无法被CPU 使用。

2.4.2 存储单元


  1. 存储器被划分为若干个存储单元,每个存储单元从0开始顺序编号。假设一个存储器有128个存储单元,则编号从0~127。
  2. 每个存储单位可以存储1个字节Byte,即8个bit。假设一个存储器有128个存储单元,则可以存储128B的内容。

2.4.3 分类


  1. 从读写属性上看分为两类:
    (1)随机存储器(RAM)
    (2)只读存储器(ROM)
  2. 从功能和连接上分类:
    (1)随机存储器RAM
    (2)装有BIOS的ROM
    (3)接口卡上的RAM

2.4.4 各类存储器的逻辑连接

各类存储器的逻辑连接示意如下,主板上各类存储器在物理上虽是独立的器件,但是它们在以下两点上相同:
(1)都和CPU的总线相连。
(2)CPU对它们进行读或写的时候都通过控制线发出内存读写命令。
在这里插入图片描述

2.5 CPU对存储器的读写


  1. CPU要想进行数据的读写,必须和外部器件(标准的说法是芯片)进行三类信息的交互:
    (1)存储单元的地址(地址信息)
    (2)器件的选择,读或写命令(控制信息)
    (3)读或写的数据(数据信息)
  2. 那么CPU是通过什么将地址、数据和控制信息传到存储芯片中的呢?
    电子计算机能处理、传输的信息都是电信号,电信号当然要用导线传送。在计算机中专门有连接CPU和其他芯片的导线,通常称为总线。
  3. 理解CPU往存储器中读写数据的过程。

2.6 总线


2.6.1 总线概述


  1. 物理上:一根根导线的集合;
  2. 逻辑上划分为:
    (1)地址总线
    (2)数据总线
    (3)控制总线
    在这里插入图片描述

2.6.2 地址总线


  1. CPU是通过地址总线来指定存储单元的。
  2. 地址总线上能传送多少个不同的信息,CPU就可以对多少个存储单元进行寻址。
  3. 一个CPU有N根地址总线,则可以说这个CPU的地址总线的宽度为N。这样的CPU最多可以寻找2的N次方个内存单元。

2.6.3 数据总线


  1. CPU与内存或其它器件之间的数据传送是通过数据总线来进行的。
  2. 数据总线的宽度决定了CPU和外界的数据传送速度,8根数据总线可以1次传输8位数据,即1个字节,16根数据总线可以1次传输16位数据,即2个字节。



2.6.4控制总线


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

2.7 主板

在每一台PC机中,都有一个主板,主板上有核心器件和一些主要器件。这些器件通过总线(地址总线、数据总线、控制总线)相连。

2.8 接口卡

计算机系统中,所有可用程序控制其工作的设备,必须受到CPU的控制。CPU对外部设备不能直接控制,如显示器、音箱、打印机等。直接控制这些设备进行工作的是插在扩展插槽上的接口卡。

2.9 内存地址空间


  1. 内存地址空间:一个CPU的地址线宽度为10,那么可以寻址1024个内存单元,这1024个可寻到的内存单元就构成这个CPU的内存地址空间。
  2. 存储器与内存地址空间:CPU在操作各存储器时,把他们都当做内存来对待,把它们总的看做一个由若干存储单位组成的逻辑存储器,这个逻辑存储器就是我们所说的内存地址空间。
    (1)所有的物理存储器被看作一个由若干存储单元组成的逻辑存储器;
    (2)每个物理存储器在这个逻辑存储器中占有一个地址段,即一段地址空间;
    (3)CPU在这段地址空间中读写数据,实际上就是在相对应的物理存储器中读写数据。
    在这里插入图片描述

3 小结
  1. 汇编指令是机器指令的助记符,同机器指令一一对应。
  2. 每一种CPU都有自己的汇编指令集。
  3. CPU可以直接使用的信息在存储器中存放。
  4. 在存储器中指令和数据没有任何区别,都是二进制信息。
  5. 存储单元从零开始顺序编号。
  6. 一个存储单元可以存储 8 个 bit (用作单位写成“b”),即 8 位二进制数,即1个字节。
  7. 每一个CPU芯片都有许多管脚,这些管脚和总线相连。也可以说,这些管脚引出总线。一个CPU可以引出三种总线的宽度标志了这个CPU的不同方面的性能:
    (1)地址总线的宽度决定了CPU的寻址能力;
    (2)数据总线的宽度决定了CPU与其它器件进行数据传送时的一次数据传送量;
    (3)控制总线宽度决定了CPU对系统中其它器件的控制能力。
  8. 核心思维:最终运行程序的是CPU,我们用汇编编程的时候,必须要从CPU角度考虑问题。
    对CPU来讲,系统中的所有存储器中的存储单元都处于一个统一的逻辑存储器中,它的容量受CPU寻址能力的限制。这个逻辑存储器即是我们所说的内存地址空间。

参考文献
  1. 《汇编语言(第3版) 》王爽著,主要参考书籍和学习路线。
    百度云:https://pan.baidu.com/s/1TE1Egc0ZmeJfLP5zvamo0Q
    提取码:3y72
  2. 《汇编语言百科》
  3. 《汇编语言基础01》小甲鱼零基础视频课程
  4. 《汇编语言基础02》小甲鱼零基础视频课程
  5. 《汇编语言基础03》小甲鱼零基础视频课程
  6. 《汇编语言基础04》小甲鱼零基础视频课程
  7. 《汇编语言基础05》小甲鱼零基础视频课程
  8. 《汇编语言学习笔记》

推荐阅读
  • 在当前的软件开发领域,Lua 作为一种轻量级脚本语言,在 .NET 生态系统中的应用逐渐受到关注。本文探讨了 Lua 在 .NET 环境下的集成方法及其面临的挑战,包括性能优化、互操作性和生态支持等方面。尽管存在一定的技术障碍,但通过不断的学习和实践,开发者能够克服这些困难,拓展 Lua 在 .NET 中的应用场景。 ... [详细]
  • 在 Linux 环境下,多线程编程是实现高效并发处理的重要技术。本文通过具体的实战案例,详细分析了多线程编程的关键技术和常见问题。文章首先介绍了多线程的基本概念和创建方法,然后通过实例代码展示了如何使用 pthreads 库进行线程同步和通信。此外,还探讨了多线程程序中的性能优化技巧和调试方法,为开发者提供了宝贵的实践经验。 ... [详细]
  • 【系统架构师精讲】(16):操作系统核心概念——寄存器、内存与缓存机制详解
    在计算机系统架构中,中央处理器(CPU)内部集成了多种高速存储组件,用于临时存储指令、数据和地址。这些组件包括指令寄存器(IR)、程序计数器(PC)和累加器(ACC)。寄存器作为集成电路中的关键存储单元,由触发器构成,具备极高的读写速度,使得数据传输非常迅速。根据功能不同,寄存器可分为基本寄存器和移位寄存器,各自在数据处理中发挥重要作用。此外,寄存器与内存和缓存机制的协同工作,确保了系统的高效运行。 ... [详细]
  • 2018 HDU 多校联合第五场 G题:Glad You Game(线段树优化解法)
    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6356在《Glad You Game》中,Steve 面临一个复杂的区间操作问题。该题可以通过线段树进行高效优化。具体来说,线段树能够快速处理区间更新和查询操作,从而大大提高了算法的效率。本文详细介绍了线段树的构建和维护方法,并给出了具体的代码实现,帮助读者更好地理解和应用这一数据结构。 ... [详细]
  • 解决针织难题:R语言编程技巧与常见错误分析 ... [详细]
  • 解题心得:UVA1339(逻辑分析与字符串处理+排序算法)
    解题心得:UVA1339(逻辑分析与字符串处理+排序算法) ... [详细]
  • 观察 | 求职体验:收到录用通知的公司通常不深究技术细节,而那些详细追问的公司往往没有后续进展
    观察 | 求职体验:收到录用通知的公司通常不深究技术细节,而那些详细追问的公司往往没有后续进展 ... [详细]
  • C++ 开发实战:实用技巧与经验分享
    C++ 开发实战:实用技巧与经验分享 ... [详细]
  • 在开发过程中,我最初也依赖于功能全面但操作繁琐的集成开发环境(IDE),如Borland Delphi 和 Microsoft Visual Studio。然而,随着对高效开发的追求,我逐渐转向了更加轻量级和灵活的工具组合。通过 CLIfe,我构建了一个高度定制化的开发环境,不仅提高了代码编写效率,还简化了项目管理流程。这一配置结合了多种强大的命令行工具和插件,使我在日常开发中能够更加得心应手。 ... [详细]
  • 如何利用Java 5 Executor框架高效构建和管理线程池
    Java 5 引入了 Executor 框架,为开发人员提供了一种高效管理和构建线程池的方法。该框架通过将任务提交与任务执行分离,简化了多线程编程的复杂性。利用 Executor 框架,开发人员可以更灵活地控制线程的创建、分配和管理,从而提高服务器端应用的性能和响应能力。此外,该框架还提供了多种线程池实现,如固定线程池、缓存线程池和单线程池,以适应不同的应用场景和需求。 ... [详细]
  • 第六章:枚举类型与switch结构的应用分析
    第六章深入探讨了枚举类型与 `switch` 结构在编程中的应用。枚举类型(`enum`)是一种将一组相关常量组织在一起的数据类型,广泛存在于多种编程语言中。例如,在 Cocoa 框架中,处理文本对齐时常用 `NSTextAlignment` 枚举来表示不同的对齐方式。通过结合 `switch` 结构,可以更清晰、高效地实现基于枚举值的逻辑分支,提高代码的可读性和维护性。 ... [详细]
  • 如何精通编程语言:全面指南与实用技巧
    如何精通编程语言:全面指南与实用技巧 ... [详细]
  • 本文介绍了如何在iOS平台上使用GLSL着色器将YV12格式的视频帧数据转换为RGB格式,并展示了转换后的图像效果。通过详细的技术实现步骤和代码示例,读者可以轻松掌握这一过程,适用于需要进行视频处理的应用开发。 ... [详细]
  • 国产PLC软件PikePLC:基于IEC 61131-3 V2.0标准的扩展与创新
    PikePLC在遵循IEC 61131-3 V2.0标准的基础上,对ST编程语言进行了多项扩展与创新。具体而言,PikePLC引入了对“BIT”类型变量的支持,允许用户在变量定时中定义此类变量。此外,该软件还增强了对位类型和整数类型变量的按位访问功能,进一步提升了编程的灵活性和效率。这些改进不仅丰富了编程语言的功能,还为工业自动化应用提供了更强大的支持。 ... [详细]
  • Apple Watch心电图功能或将在欧洲地区推出
    据最新消息,苹果公司计划在欧洲地区推出Apple Watch的心电图(ECG)功能。这一功能最早于2018年12月通过iOS 5.1.2系统更新在Apple Watch Series 4上实现,使其具备了医疗级心电图监测能力。该功能能够帮助用户实时监测心脏健康状况,及时发现潜在的心律不齐等问题,进一步提升用户的健康管理体验。 ... [详细]
author-avatar
语笑嫣然小公主155
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有