汇编入门学习笔记 (七)—— dp,div,dup
疯狂的暑假学习之 汇编入门学习笔记 (七)—— dp。div。dup
參考: 《汇编语言》 王爽 第8章
1. bx、si、di、和 bp
8086CPU仅仅有4个寄存器能够用 “[...]” 中进行单元寻址。
bp:除了默认的段地址是ss。其它与bx一样。
它们全部正确的组合
mov ax,[bx]
mov ax,[si]
mov ax,[di]
mov ax,[dp]
mov ax,[bx+si]
mov ax,[bx+di]
mov ax,[bp+si]
mov ax,[bp+di]
mov ax,[bx+si+idata]
mov ax,[bx+di+idata]
mov ax,[bp+si+idata]
mov ax,[bp+di+idata]
注意:bx与bp不能够同一时候使用,如[bx+bp]是错误的。
2. 指明要处理的数据长度
word ptr 表示字
byte ptr 表示字节
像这样,寄存器就直接指定了数据的长度:
mov ax,1
mov ax,ds:[0]
可是,看以下的样例:
assume cs:code,ds:data data segment
dw 1111H,1111H,1111H,1111H,1111H,1111H,1111H,1111H
data ends code segment
start: mov ax,data
mov ds,ax
mov ds:[0],1 ;Error mov ax,4c00H
int 21H
code ends end start
这样编译会报错,由于编译器不知道1是8位还是16位。
改进:
assume cs:code,ds:data data segment
dw 1111H,1111H,1111H,1111H,1111H,1111H,1111H,1111H
data ends code segment
start: mov ax,data
mov ds,ax
mov byte ptr ds:[0],1 ;Error mov ax,4c00H
int 21H
code ends end start
加上byte ptr 或者 word ptr才对。
加上byte ptr时,执行后,ds段中的值为: 0B56:0000 01 11 11 11 11 11 11 11-11 11 11 11 11 11 11 11
加上word ptr时,执行后,ds段中的值为:0B56:0000 01 00 11 11 11 11 11 11-11 11 11 11 11 11 11 11
样例:
assume cs:code,ds:data data segment
dw 00FFH
data ends code segment
start: mov ax,data
mov ds,ax
inc byte ptr ds:[0] mov ax,4c00H
int 21H
code ends end start
inc byte ptr ds:[0] 后,ds:[0] ds:[1] 为 00 00
假设改为inc word ptr ds:[0],执行后 ds:[0] ds:[1] 位 00 01
3. 伪指令dd,div指令
伪指令dd 表示32位,dw表示16位,db表示8位。样例见以下。
div 是除法指令。格式:div 除数
除数有两种,假设是8位的,被除数就是16位的,且存放在ax中。运算结果:商存放在 al 中,余数存放在 ah 中
假设除数是16位的,被除数就是32位的,且低16位放在 ax 中。高16位就存放在 dx 中。
运算结果:商存放在 ax
中,余数存放在 dx 中被除数就是32位的样例:
assume cs:code,ds:data data segment
dd 100001
dw 100
dw 0
data ends code segment
start: mov ax,data
mov ds,ax
mov ax,ds:[0]
mov dx,ds:[2]
div word ptr ds:[4]
mov ds:[6],ax mov ax,4c00H
int 21H
code ends end start
执行后ax为03E8H ,dx 为0001H
4. dup
dup 要与dd。dw,db配合使用,用来反复定义数据
样例:
db 3 dup (0)
定义了3个字节,它们都是0。相当于 db 0,0,0
db 3 dup (0,1,2)
定义了9个字节,它们是0、1、2、0、1、2、0、1、2
相当于 db 0,1,2,0,1,2,0,1,2
db 3 dup('abc','ABC')
定义了18个字符。它们是 ‘abcABCabcABCabcABC’
相当于 db ‘abcABCabcABCabcABC’
汇编入门学习笔记 (七)—— dp,div,dup的更多相关文章
- 汇编入门学习笔记 (九)—— call和ret
疯狂的暑假学习之 汇编入门学习笔记 (九)-- call和ret 參考: <汇编语言> 王爽 第10章 call和ret都是转移指令. 1. ret和retf ret指令:用栈中的数据 ...
- 汇编入门学习笔记 (十二)—— int指令、port
疯狂的暑假学习之 汇编入门学习笔记 (十二)-- int指令.port 參考: <汇编语言> 王爽 第13.14章 一.int指令 1. int指令引发的中断 int n指令,相当于引 ...
- Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer
原文:Elasticsearch7.X 入门学习第七课笔记-----Mapping多字段与自定义Analyzer 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处 ...
- React 入门学习笔记整理目录
React 入门学习笔记整理(一)--搭建环境 React 入门学习笔记整理(二)-- JSX简介与语法 React 入门学习笔记整理(三)-- 组件 React 入门学习笔记整理(四)-- 事件 R ...
- python3.4学习笔记(七) 学习网站博客推荐
python3.4学习笔记(七) 学习网站博客推荐 深入 Python 3http://sebug.net/paper/books/dive-into-python3/<深入 Python 3& ...
- Three入门学习笔记整理
一.官方网站:https://threejs.org 二.关于Three.js 三.开始 四.实例 基本结构 结果 五.概念 坐标系 场景 相机 灯光 3D模型 六.简单动画 七.交互控制 结束 # ...
- Sass简单、快速上手_Sass快速入门学习笔记总结
Sass是世界上最成熟.稳定和强大的专业级css扩展语言 ,除了Sass是css的一种预处理器语言,类似的语言还有Less,Stylus等. 这篇文章关于Sass快速入门学习笔记. 资源网站大全 ht ...
- Hadoop入门学习笔记---part4
紧接着<Hadoop入门学习笔记---part3>中的继续了解如何用java在程序中操作HDFS. 众所周知,对文件的操作无非是创建,查看,下载,删除.下面我们就开始应用java程序进行操 ...
- Hadoop入门学习笔记---part3
2015年元旦,好好学习,天天向上.良好的开端是成功的一半,任何学习都不能中断,只有坚持才会出结果.继续学习Hadoop.冰冻三尺,非一日之寒! 经过Hadoop的伪分布集群环境的搭建,基本对Hado ...
随机推荐
- UITableViewCell状态切换效果
UITableViewCell状态切换效果 效果图 源码 https://github.com/YouXianMing/Animations // // TableViewTapAnimationCo ...
- UIScrollView视差效果动画
UIScrollView视差效果动画 效果 源码 https://github.com/YouXianMing/Animations // // ScrollImageViewController.m ...
- Java开发环境搭建详解
一.jdk安装与配置 jdk7于3月份刚刚发布,目前eclipse的最新版本中还没有提供对jdk7的编译支持,所以我们只下载jdk6. 下载地址:http://download.java.net/jd ...
- 显示Mysql中的所有用户
在mysql中如何显示所有用户? 1.show databases显示所有数据库 2.show tables显示所有数据表 3.select current_user();显示当前用户 4.显示所有用 ...
- [20] 鼓状物(Drum)图形的生成算法
顶点数据的生成 bool YfBuildDrumVertices ( Yreal radius, Yreal assistRadius, Yuint slices, Yuint stacks, YeO ...
- 原创D3D几何实例化的DEMO
CUBE的几何实例化DEMO 鼠标右键按下并拖动 旋转视角WSAD 前后左右RF ...
- libevent的hello world程序
照着例子写了一个简单的libevent hello world代码: #include <sys/signal.h> #include <event.h> void signa ...
- Horspool 字符串匹配算法
Horspool 字符串匹配算法对Boyer-Moore算法的简化算法. Horspool 算法是一种基于后缀匹配的方法,是一种“跳跃式”匹配算法,具有sub-linear亚线性时间复杂度. Hors ...
- 几个不同版本的framework改进
一些主要的演变过程及改进,还有很多部分不可能一一列出,下面是从1.1到4.0的一些主要改进: 一..NET Framework 1.1版本 1.ASP.NET移动控件 2.ADO.NET的改动 添加S ...
- C#_文件读写常用类介绍
首先要熟悉.NET中处理文件和文件夹的操作.File类和Directory类是其中最主要的两个类.了解它们将对后面功能的实现提供很大的便利. 本节先对和文件系统相关的两个.NET类进行简要介 ...