收藏夹吃灰版!汇编语言快速入门(非常详细)

C语言与CPP编程 2024-06-07 09:01


Part1内容的定义

1.1 数据段的定义

汇编语言程序以段为单位进行书写,一般把数据定义在数据段里,程序写在代码段中。下面给出段的定义语法:

段名  SEGMENT
...(段的内容)...
段名 ENDS

注意事项:

  1. 汇编语言不区分字母的大小写

  2. 汇编语言中一行只能有一条语句

  3. 段的名字用字母或下划线开头,需要做到含义清晰且不能与保留字重名

  4. 汇编语言中用英文分号后的内容表示程序注释

  5. 不能在一个段的内部定义另一个段,也就是各个段之间相互独立

1.2 数据的定义

数据的定义是指对给出的数据分配存储单元,并将它们以标准的格式存放到数据段中。数据定义的语句元素包括DB DW DD DQ DT等。

1.2.1 定义字节数据DB

给出下面的汇编程序段

DATA  SEGMENT
X DB -1,255,'A',3+2,?
DB "ABC",0FFH,11001010B
Y DB 3 DUP(?)
DATA ENDS

下面对上面的代码段进行解释:

  1. 变量的定义X和Y称为变量名,表示程序员定义了两个变量X和Y。与高级语言不同,汇编语言中的变量实际上是后面第一个数据的地址,变量名代表了后面的若干个数据

  2. 字节数据的定义DB表示定义的数据类型都是字节类型。DB可以用于定义整数(包括正数和负数,可以使用十进制、十六进制或二进制)以及字符

  3. 求值表达式定义数据时可以出现简单的求值表达式的结果。如上方的DB 3+2相当于 DB 5

  4. 未知值的定义用问号表示一个暂时还不确定的值,一般先用0进行这个单元的填充

  5. 多个字符的定义可以出现用双引号括起来的多个字符,这些字符将分开并按照顺序进行存储;

  6. 重复定义相同数据DUP表示重复定义多个相同的数据。语法如下

  7. 隔行定义如果数据太多一行写不下,则可以另起一行继续定义。不需要重新写变量名,但是需要重新写DB伪指令

1.2.2 定义字数据DW

字数据的位数为16位,只需要将上面字节定义的语法中的DB修改为DW即可。

1.2.3 定义双字数据DD

双字数据为32字节,只需要将上面字节定义的语法中的DB修改为DD即可。需要注意的是,数据的高位存放在地址较大的单元里,数据的低位存放在地址较小的单元里。

1.2.4 定义八字节和十字节数据DQ DT

只需要将DB伪指令修改为DQ和DT即可。

Part2数据的传送

2.1 指令语句的格式

指令语句是指与一条机器指令相对应的代码语句,其一般格式如下:

[标号:]  操作码 [操作数] [;注释]

语法解释:

  1. 标号是指程序员为这一条指令语句所起的名字。大多数指令语句都不需要标号,只有一些特殊的指令语句需要用到

  2. 操作码指定本条指令的操作类型,所有的操作码都是保留字

  3. 操作数可以是0-3个,有多个操作数时彼此之间用逗号分隔。右边的操作数为源操作数,最左边的操作数为目的操作数


2.2 操作数的分类

操作数可以分为寄存器操作数、立即数操作数和存储器操作数三类。关于寄存器操作数,需要注意的是寄存器IP和FLAGS不能作为操作数出现在指令中;关于立即数操作数,需要注意的是立即数操作数不能用作目的操作数。下面着重介绍存储器操作数,先介绍两点基础知识:

  1. 存储器操作数表示对一个存储器单元进行访问,需要给出这个存储单元的段基址和偏移地址两部分才能进行

  2. 大多数情况下,指令将自动使用DS寄存器中的内容作为操作数的段基址,因此,编写汇编语言源程序时首先要做的事情就是把数据段的段基址放入DS寄存器

既然我们已经设置好了段基址,那么只需要有偏移地址即可找到内存中正确的存储单元。给出偏移地址的方法有直接和间接两种方法。直接法是指直接在指令中写出存储单元的偏移地址,间接法则是把存储单元的偏移地址事先装入一个寄存器中,需要时通过这个寄存器中的值来找到这个存储单元。

(1)直接法语法

MOV  目的寄存器,  变量名[+字节偏移量]

此语句的作用是以DS寄存器中的内容作为段基址,以数据段中指定变量名的偏移量(与字节偏移量)的和作为偏移地址,将指定存储单元中的值放入目的寄存器中。

(2)间接法语法:

MOV  间接寻址寄存器,  OFFSET 变量名
(下面是需要使用偏移地址时的语句)
MOV 目的寄存器, 间接寻址寄存器

语法解释:

  1. OFFSET是保留字,表示取出后面变量的偏移地址

  2. 间接寻址寄存器只能是BX BP SI DI中的一个如果没有另外说明,那么使用BX、SI和DI时自动以DS中的内容作为段基址,使用BP时自动使用SS的值作为段基址。

2.3 程序段的定义

程序段的一般格式如下:

CODE SEGMENT
ASSUME CS:CODE, DS:DATA
START: MOV AX, DATA
MOV DS, AX
...(其他指令部分)...
MOV AX, 4C00H
INT 21H
CODE ENDS
END START

语法解读:

  1. 程序开始的两条指令都是用于装载数据段寄存器DS的进入程序后,代码段寄存器CS中的值已经由操作系统自动设置为代码段的段基址,数据段的段基址则需要程序员手动装入DS中

  2. ASSUME伪指令用于指定每一个数据段所对应的段基址寄存器如上面的代码中CODE段的段基址寄存器为CS,DATA段的段基址寄存器为DS

  3. INT 21H表示调用由操作系统提供的21H号服务程序服务的种类由AH中的功能号决定,本例中4CH表示返回操作系统的操作;AL中的代码称为返回代码,用返回代码00H表示正常返回

  4. END伪指令标志整个程序的结束END语句下面书写的任何代码都不会被汇编。END后的标号表示程序的入口地址,也就是汇编程序开始执行的地方。

2.4 基本传送指令

基本传送指令是使用最频繁的指令,需要熟练掌握。格式如下:

MOV  目的操作数, 源操作数

语法解释:

  1. 源操作数和目的操作数的类型必须相同如果不相同只有使用强制类型转换后才能进行传送。强制类型转换语法可以见下方

  2. 源操作数和目的操作数不能同时是存储器操作数,也不能同时是段寄存器

  3. 目的操作数不能是立即数

  4. 代码段基址寄存器CS不能作目的操作数

  5. 使用立即数作为源操作数时,立即数会按照目的操作数的类型进行扩展。

强制类型转换语法(要谨慎使用)

数据类型  PTR[变量名]

Part3堆栈

3.1 堆栈的定义

堆栈也是用户使用的存储器的一部分,用于存放临时性的数据和一些其他信息。堆栈段的定义语法如下:

堆栈名  SEGMENT  STACK
(堆栈内容)
堆栈名 ENDS

语法解释:

  1. 堆栈定义和一般段的定义的唯一区别在于使用了STACK

  2. 对于堆栈段,系统会在装入程序时自动把SSEG的段基址放入SS寄存器中,堆栈中的字节数自动置入SP寄存器中

  3. 堆栈段中的内容从较大的地址开始分配和使用

  4. 对于8086CPU,进出堆栈的只能是2字节的数据。

3.2 堆栈的使用方法

常用的堆栈相关指令包括PUSH POP PUSHF和POPF,语法如下:

PUSH 源操作数              ;将指定操作数入栈保护
POP 目的操作数 ;将栈顶操作数恢复到指定位置
PUSHF ;标志寄存器内容入栈保护
POPF ;标志寄存器出栈恢复

Part4常用操作数表达式

4.1 符号定义伪指令

符号定义相当于C语言中的#define编译预处理,用于进行符号的等价替换,符号定义的语法如下所示:

符号名   EQU   表达式

语法解释:

  1. 在进行汇编时,对EQU定义的符号名用对应的表达式进行等价替换

  2. 对用EQU定义的符号名不允许重复定义。

另一种进行符号定义的方式是使用“=”符号,具体语法如下:

符号名   =   常数表达式

语法解释:

使用等号定义符号时只能使用常量表达式。

4.2 取段基址

可以使用SEG来取地址表达式所在段的段基址,具体使用方法为:

SEG 地址表达式

Part5算术运算

5.1 加法指令

对于两个操作数相加应该使用ADD指令,指令语法如下:

ADD   目的操作数, 源操作数

语法解释:

  1. 该指令将目的操作数与源操作数相加,结果存放在目的操作数原先的存放位置

  2. ADD指令执行后会刷新CPU的状态标志位。

除此之外,还有一条INC指令实现操作数的自增,语法如下:

INC   操作数

语法解释:

  1. 增量执行执行后不影响CPU的状态标志位

  2. 增量指令常常用于修改计数器以及存储器指针的值。

5.2 减法指令

减法指令和加法指令的使用是对称的。加法中的ADD对应减法中的SUB;加法中的INC对应减法中的DEC。

5.3 乘法指令和除法指令

乘法指令为MUL,除法指令为DIV,使用方法和加减法类似。由于乘除法使用较少,因此不过多介绍。

Part6循环

循环指令的语法如下:

LOOP   标号

语法解释:

  1. 循环的次数由寄存器CX中的值决定。每一次循环后CX寄存器中的值会自减1,当CX=0时循环终止,因此CX也被称为计数器

  2. 装载寄存器CX的过程应该在循环开始之前完成

  3. 每一次循环成功则回到标号处的语句。

Part7逻辑运算

逻辑运算有AND OR XOR和NOT四种,使用语法如下:

逻辑运算操作码   目的操作数   源操作数

使用情况:

  1. AND指令主要用于对操作数的各位有选择地清零

  2. OR指令主要用于对操作数各位有选择地置一

  3. XOR指令主要用于对操作数各位有选择地取反

  4. NOT指令主要用于对操作数整体取反。

Part8中断调用

所有的DOS系统功能调用都是通过软中断指令INT 21H来实现的。INT 21H是一个具有90多个子功能的中断服务程序。INT 21H对每一个子功能都进行了编号,这个编程成为功能号。

DOS系统功能调用方法:

MOV 功能号   ;把功能号放入寄存器AH中
......
(在其他寄存器中放入该功能要求的入口参数)
......
INT 21H ;调用DOS系统功能

常用功能:

8.1 键盘输入单字符

功能号1,输入字符以ASCII码的形式存放在累加器AL中同时显示出来。

MOV AH 01
INT 21H

8.2 屏幕显示单字符

功能号2,屏幕显示存放在DL寄存器中的字符。

MOV AH 02
MOV DL 待显示字符
INT 21H

8.3 屏幕显示字符串

功能号9,用于在显示器上显示一个存放在寄存器DX中的字符串,被显示的字符串必须以’$'作为结束符。

MOV AH 09
MOV DX 待显示字符串首地址
INT 21H

8.4 返回DOS

一个程序执行完成后使得程序正常退出并返回DOS的功能,功能号为4CH。

MOV AH 4CH
INT 21H

Part9子程序的定义和调用

9.1 定义子程序

子程序名 PROC
...
RET ;表示子程序返回
子程序名 ENDP ;表示子程序段定义结束

9.2 调用子程序

CALL 子程序名

Part10对接口中的端口进行读写

MOV DX 端口地址
......
(其他寄存器初始化)
......
OUT DX 需要传输到端口的数据所在的寄存器

Part11空指令延时

使用NOP表示执行一条空指令,不进行任何操作。当指令之间需要有延时时,可以插入NOP指令。

NOP

Part12选择结构

12.1 CMP指令

CMP指令格式如下:

CMP 目的操作数,源操作数

语法解释:

  1. CMP用于比较两个同类型的操作数的大小;

  2. 指令执行的结果不会修改两个操作数,而是修改标志位;

  3. CMP指令常常与下列指令结合使用。

JGE 前>=后     Jump if  greater or equal
JG 前>后 Jump if greater
JLE 前<=后 Jump if less or equal
JL 前<后 Jump if less
JNE 前不等于后 Jump if not equal
JE 前等于后 Jump if equal
文章已获作者授权转载,版权归原作者所有,如有侵权,与本账号无关,可联系删除。https://blog.csdn.net/hanmo22357/article/details/127883179
EOF

你好,我是飞宇,本硕均于某中流985 CS就读,先后于百度搜索字节跳动电商以及携程等部门担任Linux C/C++后端研发工程师。

最近跟朋友一起开发了一个新的网站:编程资源网,已经收录了不少资源(附赠下载地址),如果屏幕前的靓仔/女想要学习编程找不到合适资源的话,不妨来我们的网站看看,欢迎扫码下方二维码白嫖~

同时,我也是知乎博主@韩飞宇,日常分享C/C++、计算机学习经验、工作体会,欢迎点击此处查看我以前的学习笔记&经验&分享的资源。

我组建了一些社群一起交流,群里有大牛也有小白,如果你有意可以一起进群交流。

欢迎你添加我的微信,我拉你进技术交流群。此外,我也会经常在微信上分享一些计算机学习经验以及工作体验,还有一些内推机会

加个微信,打开另一扇窗

C语言与CPP编程 C语言/C++开发,C语言/C++基础知识,C语言/C++学习路线,C语言/C++进阶,数据结构;算法;python;计算机基础等
评论 (0)
  • 近年来,越来越多的企业在5S管理的基础上,开始追求6S、7S甚至8S管理,仿佛S越多,管理就越先进,企业就越优秀。于是,6S增加了“安全”,7S又加上了“节约”,8S甚至引入了“学习”……看似更加全面,实则很多企业只是机械地增加S,却忽略了管理的核心目标:提升效率、降低浪费、优化工作环境。优思学院认为,5S本身已经是一套成熟的精益管理工具,它的核心理念不仅简单高效,而且易于实施和推广。如果企业只是为了赶时髦,盲目增加S,而没有真正理解5S的本质,那么这些额外的“S”很可能会变成管理上的负担,而不
    优思学院 2025-03-07 12:43 165浏览
  • 深圳触觉智能RK3506开发板现已上市,开启预售!搭载瑞芯微RK3506B/J超低功耗工业处理器(1.5GHz三核A7+M0,主频1.5GHz);支持1280×1280显示、双百兆网口、星闪无线三模,板载高达2路CAN FD与5路串口。RK3506适用场景简介工业控制‌:RK3506适用于工业控制、工业通信、人机交互等应用场景。其多核异构架构(3xCortex-A7+Cortex-M0)和外设接口丰富,支持Buildroot、Yocto系统,适合轻量级HMI应用‌。‌工业通信‌:RK3506均支
    Industio_触觉智能 2025-03-07 10:04 119浏览
  • 一、系统概述MYD-LD25X搭载的Debian系统包含以太网、WIFI/BT、USB、RS485、RS232、CAN、AUDIO、HDMI显示和摄像头等功能,同时也集成了XFCE轻量化桌面、VNC远程操控、SWITCH网络交换和TSN时间敏感网络功能,为工业设备赋予“超强算力+实时响应+极简运维”的体验!类别名称描述源码TF-AArm Trusted Firmware 2.8OP-TEEOP-TEE 3.19BootloaderU-boot 2022.10KernelLinux Ke
    米尔电子嵌入式 2025-03-07 14:08 223浏览
  •        深夜的公园里,当路灯熄灭后,传统监控摄像头只能拍出模糊的黑白画面,仿佛老式胶片电影里的场景。而搭载为旌瑶光ISP的摄像头,却能像猫科动物一样,在几乎全黑的环境中捕捉到行人衣服的颜色、树叶的纹理,甚至快速跑动的宠物狗毛发细节。这种从“黑白默片”到“全彩4K电影”的跨越,背后是为旌瑶光ISP对传统红外补光技术的颠覆性创新。一、传统方案之困:被红外光“绑架”的夜视世界        传统安防摄像头依赖红外
    中科领创 2025-03-07 16:50 276浏览
  • 服务器应用环境与客户需求PCIe 5.0高速接口技术的成熟驱动着生成式AI与高效能运算等相关应用蓬勃发展。在随着企业对服务器性能的要求日益严苛,服务器更新换代的周期也持续加快。在此背景下,白牌与DIY(Do It Yourself)服务器市场迎来了新的发展契机,但同时也面临着更趋复杂的技术挑战。传统上,白牌与DIY服务器以其高度客制化与成本效益优势受到市场青睐。然而,随着PCIe 5.0等高速技术的导入,服务器系统的复杂度大幅提升,对组装技术与组件兼容性也就提出更高的要求。举个简单的例子来说,P
    百佳泰测试实验室 2025-03-06 17:00 158浏览
  • ​CS6212是一款可分别用于USB Type-C主机/显示端口源应用的带重定时的有源开关。这设备符合USB 3.2标准版本1.0和USB Type-C标准上的VESA DisplayPort Alt模式 1.0版,支持通过GPIO或12C进行灵活的模式切换。此设备支持USB 3.2第2x1代 运行速度高达10Gbps,DisplayPort 1.4运行速度高达HBR3 8.1Gbps。CS6212管脚分布及功能定义:CS6212支持重定时器训练,并支持USB 3.2标准中定义的状态状态机(RT
    QQ1540182856 2025-03-07 10:09 150浏览
  • 文/Leon编辑/cc孙聪颖2025年全国两会进行时,作为“十四五”规划收官之年,本届两会释放出坚定目标、稳中求进、以进促稳等信号。其中,企业家们的建议备受关注,关系到民营经济在2025年的走向。作为国内科技制造业的“老兵”,全国人大代表、TCL集团创始人及董事长李东生在本届两会中提出三份代表建议,包括《关于优化中国科技制造业融资环境的建议》、《关于加强AI深度伪造欺诈管理的建议》和《关于降低灵活就业人员社会保险参保门槛的建议》,表现出对科技制造、AI发展和劳动者保障方面的关注。会后,李东生接受
    华尔街科技眼 2025-03-06 19:41 123浏览
  • 深圳触觉智能SOM3506核心板现已上市,搭载瑞芯微RK3506B/J超低功耗处理器(1.5GHz三核A7+M0),低功耗满载仅0.7W,支持40℃~85℃工作环境,即日起宽温级59元/工业级68元,特价开售!芯片介绍RK3506是瑞芯微Rockchip在2024年第四季度全新推出的Arm嵌入式芯片平台,三核Cortex-A7+单核Cortex-M0多核异构设计,CPU频率达1.5Ghz, M0 MCU为200Mhz。RK3506适用场景简介工业控制‌:RK3506适用于工业控制、工业通信、人机
    Industio_触觉智能 2025-03-07 10:03 139浏览
  • 在企业管理和职场环境中,权力是一个常被提及却又让人感到微妙的话题。有人觉得它充满吸引力,有人却对它避之不及。然而,不管你对权力的态度如何,理解它、掌握它,甚至善用它,都是职场成功的重要一环。今天,我们就来深入探讨权力的本质,特别是个人权力和社会权力的区别,以及如何在职场中逐步建立属于自己的影响力。权力的两种面貌:你掌控自己,还是掌控他人?说到权力,首先要区分它的两种类型。个人权力是你对自己生活的掌控感。比如,你能自由决定自己的职业方向,不用总是请示他人。这种权力让人感到踏实和满足,是我们在生活中
    优思学院 2025-03-07 15:56 172浏览
  • Sub-GHz,即工作频段低于1GHz的无线通信技术,常见频段有315MHz、433MHz、868MHz与915MHz等。其可借助无线电波在自由空间传播的特性,把数据调制到射频载波上进行传输,达成物联网设备间的无线通信,是物联网设备实现高效、稳定、无缝交互的“通信基石”。典型射频信号(无线电波)收发电路简示在工业自动化、智慧城市、智慧农业与智能家居等物联网领域中,LoRa、Wi-SUN、Z-Wave、Sigfox等工业级通信协议大多运行在Sub-GHz频段。而正是通过Sub-GHz射频技术,传感
    华普微HOPERF 2025-03-07 11:39 142浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦