DOS-Windows汇编语言程序设计-第2章-第6节-硬指令和伪指令

PPT
  • 阅读 63 次
  • 下载 0 次
  • 页数 80 页
  • 大小 653.000 KB
  • 2022-11-12 上传
  • 收藏
  • 违规举报
  • © 版权认领
下载文档30.00 元 加入VIP免费下载
此文档由【小橙橙】提供上传,收益归文档提供者,本网站只提供存储服务。若此文档侵犯了您的版权,欢迎进行违规举报版权认领
DOS-Windows汇编语言程序设计-第2章-第6节-硬指令和伪指令
可在后台配置第一页与第二页中间广告代码
DOS-Windows汇编语言程序设计-第2章-第6节-硬指令和伪指令
可在后台配置第二页与第三页中间广告代码
DOS-Windows汇编语言程序设计-第2章-第6节-硬指令和伪指令
可在后台配置第三页与第四页中间广告代码
DOS-Windows汇编语言程序设计-第2章-第6节-硬指令和伪指令
DOS-Windows汇编语言程序设计-第2章-第6节-硬指令和伪指令
还剩10页未读,继续阅读
【这是免费文档,您可以免费阅读】
/ 80
  • 收藏
  • 违规举报
  • © 版权认领
下载文档30.00 元 加入VIP免费下载
文本内容

【文档说明】DOS-Windows汇编语言程序设计-第2章-第6节-硬指令和伪指令.ppt,共(80)页,653.000 KB,由小橙橙上传

转载请保留链接:https://www.ichengzhen.cn/view-2261.html

以下为本文档部分文字说明:

教学重点学习了8086硬指令,接着介绍MASM基本的伪指令。重点掌握:程序的格式、开发方法参数的表达、变量的定义变量和标号的属性硬指令和伪指令硬指令——使CPU产生动作、并在程序执行时才处理的语句,就是我们刚刚学习的处理器指令伪指令(Directive)——不产生CPU动作、在程序

执行前由汇编程序处理的说明性语句,例如,数据说明、变量定义等等伪指令与具体的处理器类型无关,但与汇编程序的版本有关本课程采用微软宏汇编程序MASM6.11汇编语言程序的开发本节从汇编语言程序的语句格

式出发,给出第一个示范性的汇编语言源程序,并演示汇编语言程序的过程:编辑汇编连接调试即汇编语言程序的开发方法语句格式⑴执行性语句——由硬指令构成的语句,它通常对应一条机器指令,出现在程序的代码段中:标

号:硬指令助记符操作数,操作数;注释⑵说明性语句——由伪指令构成的语句,它通常指示汇编程序如何汇编源程序:名字伪指令助记符参数,参数,…;注释MOVCX,0;传送指令,具有2个操作数DELAY:NOP;空操作指令,没有操作数,带有标号LOOPDELA

Y;循环指令,标号DELAY说明转移位置BUFFERDB1,2,3,4,5,6,7;数据定义伪指令,在主存中开辟7个连续的字节单元,初值依次为1~7,BUFFER表示首地址标号、名字与标识符标号是反映硬指令位置(逻辑地址)的标识符,后跟一个冒号分隔名字是反

映伪指令位置(逻辑地址)和属性的标识符,后跟空格或制表符分隔,没有一个冒号标识符(Identifier)一般最多由31个字母、数字及规定的特殊符号(如_、$、?、@)组成,不能以数字开头。默认情况下,汇

编程序不区别标识符中的字母大小写一个程序中,每个标识符的定义是唯一的,还不能是汇编语言采用的保留字保留字保留字(ReservedWord)是汇编程序已经利用的标识符,主要有:o硬指令助记符——例如:MOV、ADDo伪指令助记符——例如:DB、EQUo操

作符——例如:OFFSET、PTRo寄存器名——例如:AX、CSo预定义符号——例如:@data助记符硬指令助记符可以是任何一条处理器指令,也可以是一条宏指令伪指令助记符将在本节学习定义字节数据和字符串的DB就是伪指令操作数与参数处理器

指令的操作数可以是立即数、寄存器和存储单元伪指令的参数可以是常数、变量名、表达式等,可以有多个,参数之间用逗号分隔注释语句中由分号“;”开始的部分为注释内容,用以增加源程序的可读性必要时,一个语句行也可以由分号开始作为阶段性注释汇编程序在翻译源程序时将跳过该部分,不对它们做任何处理分隔符

语句的4个组成部分要用分隔符分开标号后用冒号,注释前用分号操作数之间和参数之间使用逗号分隔其他部分通常采用空格或制表符多个空格和制表符的作用与一个相同MASM支持续行符“\”汇编语言源程序的组成原则完整的汇编语言源程序由段组成一个汇编语言源程序可以包含若干个代码段、数据段

、附加段或堆栈段,段与段之间的顺序可随意排列需独立运行的程序必须包含一个代码段,并指示程序执行的起始点,一个程序只有一个起始点所有的可执行性语句必须位于某一个代码段内,说明性语句可根据需要位于任一段内通常,程序还需要一个堆栈段汇编语言源程序源程序分别用两种格式书写第一

种格式从MASM5.0开始支持简化段定义格式第二种格式MASM5.0以前就具有完整段定义格式Hello,Everybody!程序功能;test1.asm(文件名).modelsmall;定义程序的存储模式

.stack;定义堆栈段.data;定义数据段stringdb’Hello,Everybody!’,0dh,0ah,’$’;在数据段定义要显示的字符串.code;定义代码段.startup;程序起始点,建立DS、SSmovdx,offsetstring;指定字符串movah,9int21h;利用

功能调用显示信息.exit0;程序结束点,返回DOSend;汇编结束;SampleA.ASM.modelsmall.stack.data...;在数据段定义数据.code.startup;(注1)...;在代码段填入指令序列.exit0;

(注2)...;子程序代码end;(注3)简化段定义格式MASM6.x支持;test2.asm(文件名)stacksegmentstack;定义堆栈段dw512dup(?);堆栈段有512字(1024字节)空间stackends;堆栈段结束da

tasegment;定义数据段stringdb’Hello,Everybody!’,0dh,0ah,’$’dataendscodesegment’code’;定义代码段assumecs:code,ds:data,ss:stackstart:movax,data;建立DS段地址

movds,axmovdx,offsetstringmovah,9int21hmovax,4c00hint21h;利用功能调用返回DOScodeends;代码段结束endstart;汇编结束,同时指明程序起始点汇编语言程序的开发过程编辑文本编辑器,如EDIT.C

OM源程序:文件名.asm汇编汇编程序,如ML.EXE目标模块:文件名.obj连接连接程序,如LINK.EXE可执行文件:文件名.exe调试调试程序,如DEBUG.EXE应用程序错误错误错误错误开发过程1:源程序的编辑源程序文件要以ASM为扩展名源程序文件的形成(编辑)可

以通过任何一个文本编辑器实现:DOS中的全屏幕文本编辑器EDIT其他程序开发工具中的编辑环境MASM程序员工作平台PWB中的编辑环境EDITtest1.asm开发过程2:源程序的汇编汇编是将源程序翻译成由机器代码组成的目标模块文件的过程MASM

6.x提供的汇编程序是ML.EXE:ML/ctest1.asm如果源程序中没有语法错误,MASM将自动生成一个目标模块文件(TEST1.obj);否则MASM将给出相应的错误信息这时应根据错误信息,重新编辑修改源程

序后,再进行汇编开发过程3:目标模块的连接连接程序能把一个或多个目标文件和库文件合成一个可执行程序(.EXE、.COM文件):LINKtest1.obj如果没有严重错误,LINK将生成一个可执行文件(test1.exe);

否则将提示相应的错误信息这时需要根据错误信息重新修改源程序后再汇编、链接,直到生成可执行文件汇编和连接的依次自动实现ML汇编程序可自动调用LINK连接程序,实现汇编和连接的依次进行MLtest1.asm汇编程序ML.EXE可带其他参数,常用

ML/Fl/Sgtest1.asm该命令除产生模块文件test1.obj和可执行文件test1.exe外,还将生成列表文件test1.lst列表文件是一种文本文件,含有源程序和目标代码,对我们学习汇编语言程序设计和发现错误很有用。采用/

Sg选项,将在列表文件中得到有些伪指令相应的硬指令开发过程4:可执行程序的调试经汇编、连接生成的可执行程序在操作系统下只要输入文件名就可以运行:test1操作系统装载该文件进入主存,并开始运行如果出现运行错误,可以从源程序开始排错,也可以利用调试程序帮助发现错误采用

DEBUG.EXE调试程序:DEBUGtest1.exe2.3.1参数、变量和标号详细讨论汇编语言程序语句主要部分参数变量名标号并引出相关的伪指令和操作符本节重点掌握:常数的表达、变量定义伪指令DB/DW/DD、地

址操作符和类型操作符一、数值型参数在源程序语句格式的4个组成部分中,参数是指令的操作对象(在学习硬指令时被称为操作数),参数之间用逗号分隔参数根据指令不同可以没有,可以有1个、2个或多个汇编语言程序中,指令参数有数值型,它的主要形式是常数和数值表达式;硬指令的

操作数有立即数;立即数就要用数值型参数表达1、常数常数(常量)表示一个固定的数值它又分成多种形式:(1)十进制常数(2)十六进制常数(3)二进制常数(4)八进制常数(5)字符串常数(6)符号常数2、数值表达式数值表达式一般是指由运算符连接的各种常

数所构成的表达式汇编程序在汇编过程中计算表达式,最终得到一个数值程序运行之前,就已经计算出了表达式;所以,程序运行速度没有变慢,但增强程序的可读性MASM对除伪指令外各种汇编时处理的指令统称为操作符(Operator)运算符算术运算符+-*/MOD逻辑运算

符ANDORXORNOT移位运算符SHLSHR关系运算符EQNEGTLTGELE高低分离符HIGHLOWHIGHWORDLOWWORD操作符的优先级1()<>[]·LENGTHSIZEWIDTHMASK2PTROFFS

ETSEGTPYETHIS:3HIGELOW4*/MODSHLSHR5+-6EQNEGTLTGELE7NOT8AND9ORXOR10SHORT建议采用圆括号“()”显式表达,它可以极大地提高程序的可阅读性地址型参

数汇编语言程序中,指令参数还有地址型,它的主要形式是标号和名字(变量名、段名、过程名等)硬指令的操作数有存储单元;存储单元就应该用地址型参数(存储器操作数)表达二、变量定义伪指令变量定义(Define)伪指令为变量申请固定长度的存储空间,并可

同时将相应的存储单元初始化变量名伪指令助记符初值表变量定义伪指令最常使用变量名变量名为用户自定义标识符,表示初值表首元素的逻辑地址;用这个符号表示地址,常称为符号地址变量名可以没有。这种情况,汇编程序将直接

为初值表分配空间,无符号地址设置变量名是为了方便存取它指示的存储单元初值表初值表是用逗号分隔的参数主要由数值常数、表达式或?、DUP组成?——表示初值不确定,即未赋初值;DUP——表示重复初值DUP的格式为:重复次数DUP(重复

参数)变量定义伪指令助记符变量定义伪指令根据申请的主存空间单位分类DB——定义字节伪指令DW——定义字伪指令DD——定义双字伪指令DF——定义3字伪指令DQ——定义4字伪指令DT——定义10字节伪指令还有定位伪指令定义字节单元伪指令DBDB

伪指令用于分配一个或多个字节单元,并可以将它们初始化为指定值初值表中每个数据一定是字节量(Byte),存放一个8位数据:可以是0~255的无符号数或是-128~+127带符号数也可以是字符串常数dat

asegment;数据段Xdb'a',-5db2dup(100),?Ydb'ABC'dataends定义字单元伪指令DWDW伪指令用于分配一个或多个字单元,并可以将它们初始化为指定值初值表中每个数据一定是字量(Word),一个字单元可用于存放任何16位数据:一个段地址一个偏移地址两个字符0~65

535之间的无符号数-32768~+32767之间的带符号数datasegment;数据段countdw8000h,?,'AB'maxintequ64hnumberdwmaxintarraydwmaxintdup(0)dataends字变量和字常量

的定义:WNUMEQU5678H;定义WNUM为常量COUNTDW20H;定义COUNT变量,假设在数据段的偏移地址为10H字变量和字常量的应用:MOVAX,[BX+SI+WNUM];MOVAX,[BX+SI+5678H]MOVAX,COUNT;MOVAX,[0010H]M

OVAX,[SI+COUNT];MOVAX,COUNT[SI];MOVAX,[SI+10H]LEABX,COUNT;LEABX,[0010H]MOVBX,OFFSETCOUNT;MOVBX,0010H定义双字单元伪指令DDDD伪指令用于分配一个或多个双字单元,并可以

将它们初始化为指定值初值表中每个数据是一个32位的双字量(DoubleWord):可以是有符号或无符号的32位整数也可以用来表达16位段地址(高位字)和16位的偏移地址(低位字)的远指针varddDD0,?,12345678hfarpointDD00400078h其

他数据单元定义伪指令定义3字伪指令DF——用于为一个或多个6字节变量分配空间及初始化6字节常用在32位CPU中表示一个48位远指针(16位段选择器:32位偏移地址)定义4字伪指令DQ——用于为一个或多个8字节变量分配空间及初始化8字节变量可以表达一个64位整数定义

10字节伪指令DT——用于为一个或多个10字节变量分配空间及初始化10字节变量可以表达扩展精度浮点数例2:数据定义综合应用-1/2.modelsmall.stack.databvarDB16wvarDW4*3dvarDD4294967295;=232-1qva

rDQ?DB1,2,3,4,5tvarDT2345;定义了BCD码2345HabcDB'a','b','c'msgDB'Hello',13,10,'$'bbufDB12DUP('month')dbufDD25DUP(?)CALLDOSEQU<int21h>例2:数据

定义综合应用-2/2.code.startupmovbl,bvarmovax,wordptrdvar[0]movdx,wordptrdvar[2];取双字到DX.AXmovdx,offsetmsgmovah,09hCALLDOS.exit0end例3:数

据复制和显示-1/2.modelsmall.stack.datasourcedb33h,34h,35h,36h;定义4个字符数据targetdb80dup(?);分配数据空间4×20=80.code.startupmovax,dsmoves,ax;d

ata也作为附加段cldmovsi,offsetsourcemovdi,offsettargetmovcx,80例3:数据复制和显示-2/2repmovsb;串传送movsi,0;显示movbx,offsettargetagain:movdl,[b

x+si]movah,2int21hincsicmpsi,80jbagain.exit0end定位伪指令定位伪指令控制数据的偏移地址ORG参数ORG伪指令是将当前偏移地址指针指向参数表达的偏移地址:ORG100h;从100h处安排数据或程序OR

G$+10;使偏移地址加10,即跳过10个字节空间MASM中,符号“$”表示当前偏移地址值EVEN;从偶地址开始ALIGNn;从n的整数倍地址开始变量和标号的属性标号和名字一经定义便具有以下两类三种属性:①段值标号和名字对应存储单元的段地址②偏移值标号

和名字对应存储单元的偏移地址③类型标号、子程序名的类型可以是NEAR(近)和FAR(远),分别表示段内或段间变量名的类型可以是BYTE(字节)、WORD(字)和DWORD(双字)等地址属性类型属性地址操作符取得名字或标号的段地址和偏移地址两个属性[]将括起

的表达式作为存储器地址$当前偏移地址:采用指定的段地址寄存器OFFSET名字/标号返回名字或标号的偏移地址SEG名字/标号返回名字或标号的段地址org$+10arraydb45,45h.codemovax,segarraymovds,a

xmovbx,offsetarray;等价于leabx,arraymovcl,array+4;等效于movcl,array[4]movax,es:[2000h]加4个字节单元类型操作符类型操作符对名字或标号的类型属性进行有关设置类型名

PTR名字/标号THIS类型名SHORT标号TYPE名字/标号SIZEOF变量名LENGTHOF变量名类型名PTR名字/标号PTR操作符使名字或标号具有指定的类型类型名可以是BYTE/WORD/DWORD/FWORD/QWORD/TBYTE

或者是NEAR/FAR,还可以是由STRUCT、RECORD、UNION以及TYPEDEF定义的类型moval,byteptrw_var;w_var是一个字变量jmpfarptrn_label;n_label是一个标号使用PTR操作符,可以临时改变名字或标号的

类型THIS类型名利用THIS说明的操作数具有汇编时的当前逻辑地址,但具有指定的类型b_varequTHISbyte;按字节访问变量b_var,但与w_var的地址相同w_vardw10dup(0);按字访问变量w_varf_jumpequTHISfar;用f_jump为段间转移(f_ju

mplabelfar)n_jump:movax,w_var;用n_jump为段内近转移,但两者指向同一条指令LABEL伪指令的功能等同于“EQUTHIS”SHORT标名指定标号作为-128~+127字节范围内的短转移jmpshortn_jump当然,如果标号实际上超出了这个范

围,则出错。TYPE名字/标名返回表明名字或标号类型的一个字量数值对字节、字和双字变量依次返回1、2和4;对短、近和远转移依次返回ff01h、ff02h和ff05hmovax,TYPEw_var;汇编结果为movax,2movax,TYPEn_jump;汇编结果为mov

ax,0ff02h(near标号)操作符SIZEOF返回整个变量占用的字节数LENGTHOF返回整个变量的数据项数(即元素数)SIZEOF=LENGTHOF×TYPE例题:属性及其应用-1/5.modelsmall.stack.datav_byteequthis

byte;v_byte是字节类型,与变量v_word的地址相同v_worddw3332h,3735h;v_word是字类型的变量targetdw5dup(20h);分配数据空间2×5=10字节crlfd

b0dh,0ah,'$'flagdb0n_pointdwoffsets_label;取得标号s_label的偏移地址例题:属性及其应用-2/5.code.startupmoval,byteptrv_word;用PTR改变v_word的类型,否则类型不匹配

decalmovv_byte,al;对v_word的头一个字节操作,原为32H、现为31Hn_label:cmpflag,1jzs_label;flag单元为1转移incflagjmpshortn_labe

l;进行短转移例题:属性及其应用-3/5s_label:cmpflag,2jznext;flag单元为2转移incflagjmpn_point;段内的存储器间接寻址,转移到s_label标号处next:movax,typev_word;汇编结果为movax,2movcx,lengthoftarg

et;汇编结果为movcx,5例题:属性及其应用-4/5movsi,offsettargetw_again:mov[si],ax;对字单元操作incsi;SI指针加2incsiloopw_again;循环movcx,sizeoftarget

;汇编结果为movcx,0ahmoval,'?'movdi,offsettargetb_again:mov[di],al;对字节单元操作incdi;DI指针加1loopb_again;循环例题:属性及其应用-5/5movdx,offsetv_word;显示结果:1357??????????mova

h,9int21h.exit0end三、程序段的定义和属性详述汇编语言程序格式的组成部分首先,简单了解DOS支持的exe程序和com程序其次,重点掌握简化段定义格式的各条伪指令最后,理解完整段定义格式所包含的各种段属性exe程序利用程序开发工具,通常将生成EXE结构的可执行程

序(扩展名为.EXE的文件)它可以有独立的代码、数据和堆栈段,还可以有多个代码段或多个数据段,程序长度可以超过64KB,执行起始处可以任意指定当DOS装入或执行一个程序时,DOS确定当时主存最低的可用地址作为该程序的装入起始点。此点以下的区

域称为程序段。在程序段内偏移0处,DOS为该程序建立一个程序段前缀控制块PSP(ProgramSegmentPrefix),它占256(=100h)个字节;而在偏移100h处才装入程序本身com程序COM程序是一种将代码、数据和堆栈段合一的结构紧凑的程序,所有代码、数据都在一

个逻辑段内,不超过64KB在程序开发时,需要满足一定要求并采用相应参数才能正确生成COM结构的程序COM文件存储在磁盘上是主存的完全影象,不包含重新定位的加载信息,与EXE文件相比其加载速度更快,占用的磁盘空间也少尽管DOS也为COM程序建立程序段前缀PSP,但由于两种文件结构不同,所

以加载到主存后各段设置并不完全一样;SampleA.ASM.modelsmall.stack.data...;在数据段定义数据.code.startup...;在代码段填入指令序列.exit0...;子程序代码end简化段定义格式MASM6.x支持.MODEL存储模式使用简化段定义,必须有存

储模式伪指令.model语句必须位于所有段定义语句之前存储模式决定一个程序的规模,确定进行子程序调用、指令转移和数据访问的缺省属性MASM有7种不同的存储模式:①TINY②SMALL③COMPACT④MEDIUM⑤LARGE

⑥HUGE⑦FLATTINY微型模式微型模式是MASM6.0才引入的用于创建COM类型程序用微型模式编写汇编语言程序时,所有的段地址寄存器都被设置为同一值这意味着代码段、数据段、堆栈段都在同一个段内,不大于64K

B;访问操作数或指令都只需要使用16位偏移地址SMALL小型模式一般的程序(例如本书的绝大多数程序示例和习题)都可用这种模式在小型模式下,一个程序至多只能有一个代码段和一个数据段,每段不大于64KB这里的数据段是指数据段、堆栈段和附加段的

总和,它们共用同一个段基址,总长度不可超过64KB;因此小模式下程序的最大长度为128KB访问操作数或指令都只需要使用16位偏移地址;这意味着诸如指令转移、程序调用以及数据访问等都是近属性(NEAR),即小型模式下的调用类型和数据指针缺省分别为

近调用和近指针COMPACT紧凑模式适合于数据量大但代码量小的程序紧凑模式下,代码段被限制在一个不大于64KB的段内;而数据段则可以有多个,超过64KB这种模式下的调用类型缺省仍为近调用;而数据指针缺省为远(FAR)指针,因为必须用段地址来区别多个数据段MEDIUM中型模式中型模式是与

紧凑模式互补的模式适合于数据量小但代码量大的程序中型模式的代码段可以超过64KB,有多个;但数据段只能有一个不大于64KB的段这种模式下的数据指针缺省为近指针;但调用类型缺省是远(FAR)调用,因为要利用段地址区别多个代码段LARGE大型模式较大型

程序通常采用的存储模式大型模式允许的代码段和数据段都有多个,都可以超过64KB;但全部的静态数据(不能改变的数据)仍限制在64K字节内大型模式下的调用类型和数据指针缺省分别为远调用和远指针HUGE(巨型模式)与大型模式基本相同,只是静态数据不再被限制在64K字节之内FLAT平展模式

平展模式用于创建一个32位的程序,它只能运行在32位x86CPU上。DOS下不能使用FLAT模式,而编写32位Windows9.x或Windows-NT的程序时,必须采用FLAT模式。DOS下编程可选择前六种模式,一般可以选用SMALL模式TINY模式产生COM程序,其

他模式产生EXE程序,FLAT模式只能用于32位程序简化段定义伪指令.STACK[大小];堆栈段开始.DATA;数据段开始.CODE[段名];代码段开始简化段定义伪指令指明一个逻辑段的开始,同时自动结束前面的一个段采用简化段定义伪指令前,需有.model语句

使用简化段定义,各段名称和其他用户所需的信息可以使用MASM预定义符号,例如:@data表示由.data等定义的数据段的段名堆栈段伪指令.STACK[大小]堆栈段伪指令.STACK创建一个堆栈段,段名是:stack它的参数指定堆栈段所

占存储区的字节数,默认是1KB(=1024=400h字节)数据段伪指令.DATA数据段伪指令.data创建一个数据段,段名是:_DATA。它用于定义具有初值的变量,当然也允许定义无初值的变量无初值变量可以安排在另一个段中,它用.data

?伪指令创建,数据段名是:_BSS.const伪指令用于建立只读的常量数据段(段名:CONST)代码段伪指令.CODE[段名]代码段伪指令.code创建一个代码段,它的参数指定该代码段的段名如果没有给出段名,则采用默认段名:在TINY、SMALL、COMPACT和FLAT模式下,默认的代码段

名是:_TEXT在MEDIUM、LARGE和HUGE模式下,默认的代码段名是:模块名_TEXT程序开始伪指令.STARTUP按照CPU类型、存储模式、操作系统和堆栈类型,产生程序开始执行的代码;同时还指定程序开始执行的起始点在DOS下,还将设置DS值,调

整SS和SP值movdx,dgroupmovds,dx;设置DSmovbx,sssubbx,dxshlbx,1shlbx,1shlbx,1shlbx,1cli;关中断movss,dx;调整SS和SPaddsp,bxsti;开中断movdx,@

datamovds,dx程序终止伪指令.EXIT[返回参数]产生终止程序执行返回操作系统的指令代码它的可选参数是一个返回的数码,通常用0表示没有错误。例如.exit0对应的代码是:movax,4c00hint21hDOS功能调用的4ch子功能(返回DOS):入口参数:AH=4ch,

AL=返回数码汇编结束伪指令END[标号]指示汇编程序MASM到此结束汇编过程源程序的最后必须有一条END语句可选的标号用于指定程序开始执行点,连接程序将据此设置CS:IP值采用了.startup伪指令就不需要再用“end标号”指明开始

执行点,但还要有end伪指令————千万注意————程序终止和汇编结束是两码事com程序的编写利用MASM6.x的简化段定义格式,可以非常容易地创建一个COM程序遵循的规则:采用TINY模式源程序只设置代码段,无数据、堆栈等段程序必须从偏移地址100h处开始执行数

据只能安排在代码段中,注意不能与可执行代码相冲突,通常在程序最后.modeltiny;微型存储模式.code;只有代码段.startup;程序起始点,=ORG100Hmovdx,offsetstringmovah,9;显示信息int21hmovah,01h;等待按键int21h

movah,02h;响铃movdl,07hint21h.exit0;程序结束点,返回DOSstringdb‘Pressanykeytocontinue!$’;数据安排在此end;汇编结束完整段定义伪指令段名segment定位组合段字'类别'

...;语句序列段名ends完整段定义由SEGMENT和ENDS这一对伪指令实现,SEGMENT伪指令定义一个逻辑段的开始,ENDS伪指令表示一个段的结束段定义指令后的4个关键字用于确定段的各种属性,堆

栈段要采用stack组合类型,代码段应具有‘code’类别,其他为可选属性参数如果不指定,则采用默认参数;但如果指定,注意要按照上列次序

小橙橙
小橙橙
文档分享,欢迎浏览!
  • 文档 25747
  • 被下载 7
  • 被收藏 0
相关资源
广告代码123
若发现您的权益受到侵害,请立即联系客服,我们会尽快为您处理。侵权客服QQ:395972555 (支持时间:9:00-21:00) 公众号
Powered by 太赞文库
×
确认删除?