【汇编语言】数据类型的匹配问题:自动匹配与手动匹配

0 前言

本文基于8086汇编语言,不过x86系列语言具备向下兼容特点,大多数情况都可以用。

与高级语言数据类型的自动转换强制转换一样,汇编语言的数据类型也有 自动匹配手动匹配

下面,我来介绍一下汇编语言的相关原则。

1 数据类型匹配的原则

任何时候,数据的匹配,只能是完全一样的数据类型才能进行数据传送。

也就是8位对8位,16位对16位,32位对32位。

比如

  1. mov ax,bx
  2. mov al,bl

请注意,这里的原则与操作数个数无关,指令如果涉及到数据传送过程,至少也要有数据提供方,有数据接收方

在这里插入图片描述
需要注意,这里的数据传送,是copy,而不是remove,传送之后原来的数据不消失,只是复制过去。

你想问为什么是copy?先明白一个问题,计算机的本质,是电子计算机,是基于电的。你可以想象一下,有两根导线,中间有一个没有闭合的开关,开关闭合前,左边的是导线通电的,右边的不带电,现在将开关闭合,右边的导线是不是也通电了,左边的导线没有因此不带电吧?开关闭合后通电的过程,就是数据传送的过程,我想你大概能理解为什么是copy了。

2 自动匹配

由上面的图你可以看到,有三个部分

  • 数据提供方A
  • 数据传送带B
  • 数据接收方C

自动匹配分为以下情况

  • B大小固定:则A,C的大小自动固定
    • 例如:指令push,pop要求必须是字传送,也就是B的大小限定为16
    • ……
  • B大小不固定:则A,C只要有一方是固定,另一方自动固定
    • 例如:mov ax,1,因为ax固定16位,则1也要是16位,如果不是,需要变成16位的(插一句,这就是符号扩展
    • mov ax,bx,双方都固定16位也是可以的

对于B固定的情况,只有很少一部分,记住即可,这里谈一下不固定的部分。

A,C分别代表数据的提供方和接收方,它们不一定是两个操作数,也可能是隐藏的,例如有的指令是单操作数,有的没有操作数,但这都不妨碍它们都有A和C

A或C可能是

  • 寄存器
  • 内存单元

当一方为寄存器,例如使用ax,则另一方就需要是16位的数据,可以是

  • 寄存器,例如bx
  • 定义为dw类型的数据
  • 某个数据的首地址,自动按16位提取,不需要加限制条件,例如ds:[0]
  • 立即数,自动扩展为16位的

当一方为dw类型数据,也是同理。

不可以的情况:当一方为内存单元地址,另外一方为立即数,例如mov ds:[0],1,这就是手动匹配,看下一节。

3 手动匹配

A和C的大小都不能确定的时候,就需要手动匹配,加上限定条件了,这通常发生在<内存单元地址>立即数身上,因为它们是不固定大小的,如果它们结合,或者单独出现,就必须加上限制条件。

例如

  • mov word ptr ds:[0],1
  • jmp word ptr ds:[0]

只能对内存单元地址做出规定,也就是word ptrbyte ptrdword ptr等,立即数是墙头草,别人多大他多大。

4 注意事项

需要注意的是,对于数据类型匹配这件事情,取决于编译器和CPU的设计者,大多数情况是遵循我上面所说的原则的,对于极少数特殊情况,也是完全可能的,不要因此感到惊讶。

5 小结

前面解释了很多,不过你根本没有必要记忆,只需要警惕一些特殊情况即可

对于没有限定B部分的指令

  1. 双操作数指令,出现内存单元地址和立即数,地址要限定word ptr等类型
  2. 单操作数,内存单元地址要限定类型
    在这里插入图片描述

就像赛跑,规定了起点位置和长度,就能够得到终点位置

  • 起点位置就是内存单元地址,比如ds:[0]代表起点位置为ds*16 + 0
  • 长度就是数据类型,比如word ptr代表长度2个字节

对于其他指令集架构,原理上是有相通性的,请读者自行思考。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/384720.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qt制作定时关机小程序

文章目录 完成效果图ui界面ui样图 main函数窗口文件头文件cpp文件 引言 一般定时关机采用命令行模式&#xff0c;还需要我们计算在多久后关机&#xff0c;我们可以做一个小程序来定时关机 完成效果图 ui界面 <?xml version"1.0" encoding"UTF-8"?>…

Visual Studio 编译优化选项:Debug与Release、禁止优化与O1、O2、Ox优化

Debug与禁止优化 Debug模式是调试模式&#xff0c;会有很多冗余的调试代码&#xff0c;供开发者调试程序使用。 VS是默认使用Debug模式的&#xff0c;我使用的是VS 2017。 在Debug模式下&#xff0c;是默认开启禁止优化的&#xff0c;我们来查看一下 在左侧源文件的main.c处…

【数字逻辑入门】计算机如何存储1位二进制数

0 前言 本文将会以R-S锁存器为例&#xff0c;引出锁存器的核心和本质&#xff0c;之后再带你构建更多类型的锁存器&#xff0c;你能够&#xff1a; 感受到由浅入深的学习方式体会到掌握核心本质的快感深刻理解核心套外壳的设计理念&#xff08;产品迭代1.0–>2.0–>3.0…

【算法训练】DAY1:整数反转

1 前言 题目来源于Leetcode。 重点&#xff1a;理清逻辑&#xff0c;忽略细节&#xff0c;模仿高手&#xff0c;五毒神掌 2 题目分析 题目很容易理解&#xff0c;先分成两个部分 正数负数 先解决正数 最开始想到的是 intchar数组long唯一增加的就是&#xff0c;先判断整…

【蓝桥杯】BASIC-8 回文数(2020-06-08)

题目 试题 基础练习 回文数 资源限制 时间限制&#xff1a;1.0s 内存限制&#xff1a;512.0MB 问题描述   1221是一个非常特殊的数&#xff0c;它从左边读和从右边读是一样的&#xff0c;编程求所有这样的四位十进制数。    输出格式   按从小到大的顺序输出满足条件的…

【算法训练】Leetcode 1295. 统计位数为偶数的数字(2020.06.09 )

1 题目 1295. 统计位数为偶数的数字 给你一个整数数组 nums&#xff0c;请你返回其中位数为 偶数 的数字的个数。 示例 1&#xff1a; 输入&#xff1a;nums [12,345,2,6,7896] 输出&#xff1a;2 解释&#xff1a; 12 是 2 位数字&#xff08;位数为偶数&#xff09; 345 …

Vivado设置指定源文件进行RTL优化

像VS编译器设置启动项一样&#xff0c;Vivado中&#xff0c;也有类似设计&#xff0c;可以看到&#xff0c;当前选中的是ALU&#xff0c;那么进行RTL优化的时候&#xff0c;会优化RTL的结果&#xff0c;而不是别的&#xff0c;如何改成别的&#xff1f; 在某文件上右键单击选择…

【完整流程】用VSCode替换Vivado默认编辑器

本文楼主找了很多资料&#xff0c;选出了最有用的资料&#xff0c;按照教程走&#xff0c;就可以顺利搞定&#xff0c;先给出画面 很酷很方便&#xff0c;同时还有 自动补全检测错误列选自动生成仿真测试文件 等重要功能 Vivado原来的编辑器是这样的…… 关键是&#xff0c…

IEDA中JavaDoc的自动生成、手动生成,以及生成html文档

1 自动生成类的注释 JavaDoc就是java特有的一种注释。 1.1 配置 首先&#xff0c;IDEA点击File-->Settings 然后Editor-->File and Code Templates-->Class 之后在这地方&#xff0c;添加一些代码 /** * ${description} * * <p> * 创建日期&#xff1a;$…

【java】父类与子类的引用赋值关系

理清楚4个目标 父类引用&#xff08;“名”&#xff09;父类对象&#xff08;“实”&#xff09;子类引用子类对象 理清楚几个操作 // 父类 public class parent{}// 子类 public class sun{}父类引用指向父类对象 parent p1 new parent();子类引用指向子类对象 son s1 …

IDEA自动生成 构造方法 get set方法

对于一个类&#xff0c;创建好成员变量后 右键单击&#xff0c;选中Generate 然后 这几个依次是 构造方法getsetget和set 我们可以选中一个&#xff0c;然后选中要生成的变量&#xff0c;点击OK 这样就可以自动生成 构成方法get方法set方法

IDEA快速修改类名和文件名

在你要修改的类名上&#xff0c;选中类名&#xff0c;然后 右键单击选中Refactor选中Rename 也可以使用快捷键 Win用户是Shift F6

【FPGA VerilogHDL】第一次尝试:LED灯基础实验

0 实验环境 0.1 软件环境 ISE 14.7win10vivado 2017.4 0.2 硬件设备 ISE适用的FPGA开发板&#xff1a;ALINK AX309 1 需求 能够灵活控制4个LED灯 2 Verilog实现 timescale 1ns / 1ps // // Create Date: 14:18:20 08/08/2020 // Module Name: led // Revision…

使用ISE一键生成bit文件

我们知道&#xff0c;这几个&#xff0c;在第一次做好源文件之后&#xff0c;需要一个个进行右键单击-->run&#xff0c;以发现错误。 但是之后的调试&#xff0c;只要一点点变化&#xff0c;哪怕是注释变化&#xff0c;都需要重新run3次&#xff0c;太麻烦了。 不过经过实…

【FPGA Verilog】实验二:key按键基础实验

只说一下经验和教训 1 必须按照设计流程走 不要因为实验简单&#xff0c;就直接进行综合&#xff0c;比如按照 设计编码RTL优化仿真综合管脚分配&#xff0c;实现下载 一定要按照这个步骤来。 2 必须先查看开发板说明文档 开始出了一个令人困惑的问题&#xff0c;后来发现…

【Java】字符串转换为数字:Integer的parseInt方法

Java官方文档[1]的解释 public static int parseInt​(String s) throws NumberFormatException Parses the string argument as a signed decimal integer. The characters in the string must all be decimal digits, except that the first character may be an ASCII minus…

在win10上使用Vmware安装Mac OS

安装macOS 如何在Windows上VMware上安装macOS Catalina 10.15 做一些提示&#xff1a; 如果您在第一次启动mac的时候&#xff0c;在出现【语言选择】之前&#xff0c;出现了连接蓝牙内容。 您可以将教程中【修改为win10 x64】那一步跳过&#xff0c;请注意&#xff0c;如果您…

【Computer Organization】The Core Design Thinking of single cycle CPU

1 Overview This section introduces someting that maybe you need to know before learning. Note:This CPU is based on MIPS instruction set. 1.1 Tools LogisimCS 3410 ComponentsMARS MIPS simulatorWin10 or Mac OS 1.2 Courses 自己动手画CPU《计算机组织与结构实…

【汇编语言】王爽 - 内中断复习

0 前言 基于王爽《汇编语言》和Coursera的《计算机组成》课程。 1 中断分类 CPU在执行指令的过程中&#xff0c;产生了一个异常/中断&#xff0c;因为CPU只能同时执行一条指令&#xff0c;所以需要暂停该指令的执行&#xff0c;转而去处理异常/中断信息。 这个异常可以来…

【算法】蛮力法/穷举法/枚举法 的基本问题分析

炮兵问题的优化&#xff0c;设立逻辑数组 蛮力法设计思想 有策略地穷举 验证 制定穷举策略避免重复 简单来说&#xff0c;就是列举问题所有可能的解&#xff0c;然后去看看是否满足题目要求&#xff0c;是一种逆向解题方式。&#xff08;我也不知道答案是什么&#xff0c;…