a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 227|回复: 6

[PC技术] 2011年计算机三级考试PC技术考试要点(15)

[复制链接]
发表于 2012-7-31 20:55:16 | 显示全部楼层 |阅读模式
九、80X86宏汇编语言的伪指令语# k8 _: C8 u4 h9 \  Y, E
(一)基本宏汇编语言的伪指令语句
* s9 r, J, E5 ]$ w1 g8086/8088宏汇编有近60条伪指令,其大体分类如下表所示。! S: {3 Q1 M! U
表8086/8088伪指令分类
8 A# X5 Q/ u8 |2 S类别 伪指令 类别 伪指令
" z+ {) K* m8 C+ t符号定义伪操作 EQU,=,LABEL- s% x: H4 }1 |( D- ~6 B
宏处理伪操作 MACRO,ENDM,EXITM LOCAL,REPT,IRPC,IRP,PURGE
  E, l& n1 A3 K/ Q变量定义伪操作 DB,DW,DD,DQ,RECORD,STRUC 条件伪操作 IF,ENDIF,IF1,IF2,IFNB,IFE,IFDIF,IFNDFE IFIDN,ELSE% a/ Q! o  ?, _- n: X+ F* g
段定义伪操作 SEGMENT,( h4 Z  U+ w$ G5 q6 M% [
ENDS GROUP,
$ E8 p% Q5 |1 p' wASSUME,ORG( l; m9 `" Q; C8 @# P/ P- r. [
过程定义伪操作 PROC,ENDP 列表伪操作 PAGE,TITLE, SUBTTL,LIST, XLIST,%OUT
+ U2 c. ?4 r4 c* H0 r& C模块定义与通信 EXTRN,PUBLIC
' F- U3 f2 F! q- Y* qNAME,END 其他 COMMENT,RADIX INCLUDE EVEN
7 }# f8 V( o$ X9 }! B+ Y1.符号定义2 M' P( A. D' Z9 u3 O& L- U5 C7 R
符号定义伪指令可用于为表达式赋予一个符号名,表达式可以是常量、变量、标号、指令语句和字符等。在程序中,任何需要这种表达式的地方都可以用被赋予的符号名来代替它。常用的符号定义语句有等值语句(EQU)和等号语句(“=”)。7 D: a- h6 k- c6 U9 J
(1)等值语句
1 u# O- W. G3 A# k" W) h& o9 r格式:符号名 EQU 表达式
: z( |% f: m9 Y功能:用符号名代替右边的表达式的值。- I7 W' X) O' q9 R9 v2 p1 ~( m
说明:表达式可以是一个值、新符号名、可执行的命令或表达式的值。
- ], o# c  a, {: o  }" ^, R5 X! W9 }注意:在同一个源程序中,EQU语句定义的符号不能再赋予不同的值,即不能再重新定义。
+ k* a- s: h1 A& I4 n(2)等号语句
2 B. o4 _) `- n, z! U+ Q格式:符号名=表达式+ N* `  w0 k$ }3 r/ c4 I
功能:等号语句的功能和EQU语句类似,不同之处是它允许对符号名再定义。
回复

使用道具 举报

 楼主| 发表于 2012-7-31 20:55:17 | 显示全部楼层

2011年计算机三级考试PC技术考试要点(15)

2.变量定义* _4 C5 m1 {/ s+ [
变量定义语句使用伪指令DB、DW、DD、DF、DQ和DT。格式:变量名 {DB|DW|DD|DF|DQ|DT}表达式1 X2 h0 B. L. D  }7 ^4 q
功能:在内存中分配一块以变量名为名字的一个或多个字节/字/双字/长字/4字/10字的数据储区,并填入由伪指令给出的数据。说明:8 `( j# I* W/ Y, m- e5 }
①变量名是可选择的,它表示定义的一块内存单元数据区的名字。! d6 Y3 B' [2 T+ f5 d
②花括号{}中的项是可选择的伪指令,每次定义只能选择其中一种。各伪指令的意义为:
/ p. @& Q1 @0 _& U9 F( q% r) I. L●DB 定义字节数据存储区. [& Z1 A& ~9 ~! ?1 F" s6 m3 ^
●DW 定义字数据存储区) V1 J; D; ]4 g: x8 F4 J
●DD 定义双节数据存储区
) R5 B6 b- y' k2 [●DF 定义长字数据存储区+ d& v! V) }; |; H4 r* F
●DQ 定义4字数据存储区
' f) ?9 E1 ?6 k●DT 定义10字压缩BCD码数据存储区
, |/ u) j) ]. I- s2 _+ X③表达式是伪指令的操作+ r3 {  m. w  ]! q
数,它可以是数值表达式、地址表达式、ASCII码表达式、?表达式或n DUP表达式。说明如下:
; R. V$ ]0 i% K! l+ x●数值表达式7 A% g* o( j! o$ I; s
数据在存储区中存放时,左边的数据项占较小地址,右边的数据项占较大的地址;对于非DB定义的数据,高位字节占据较大地址,低位字节占据较小地址。# H" S0 U, A2 a- A0 A7 q
●地址表达式
: \" g( b: j# C* H% ]0 y8 a地址表达式的运算结果是一个地址,因而只能使用伪指令DW和DD。这时,存储单元中存放的是存储器的地址值。如果使用DW,则存放的是段内地址偏移量;如果使用DD,则存放段地址和地址偏移量。0 }2 L- I! Y8 b7 d
●ASCII码字符串表达式
' z% W1 [# S( I0 \* v" k: m; J使用伪指令DB可以定义用单引号括起来的字符串,它为字符串的每个字符分配一个存储单元,并依字符串从左到右的顺序,将字符的ASCII码按地址递增顺序放在内存中
6 Z( P5 u: H) b: x4 @●?表达式
7 H: w5 d/ ^; r2 w  a表达式?号时,表示符号名无确定值。汇编程序遇到?号时,它仍然为数据项分配存储单元,但不对它初始化。
+ D" ^4 o3 q% p, A/ z; e4 h2 b●n DUP(?)
# |/ P' |! V6 I6 E9 T9 V: h, P格式:数值表达式 DUP 项或项表
: O5 [; u5 Y. J, V- m2 R数值表达式的值表示重复的次数,其各项必须预先定义。项或项表表示重复内容,可以是?、数值、数值表达式、字符或重复子句。项表中的各项用逗号隔开。, a0 o& R0 [  H! s
当重复子句为DB、DW、DD、DQ和惟一操作数且项为?时,将不初始化数据区,该数据氏的原存信息保持不变。当重复句是惟一操作数时,定义的变量具有LENGTH和SIZE属性。4 P1 {/ i* j% p8 A7 g3 f8 m
3.标号定义伪指令1 F3 [& z, G3 V$ _, N& o
格式:符号名 LABEL 类型  M$ c6 m6 S8 m& M  J
功能:将紧跟在本伪指令语句后的标号、操作码、过程或变量建立新的符号名,并刷新其类型属性。对标号、操作码或过程,其类型为NEAR、FAR;对变量,其类型为BYTE、WORD、DWOBD、FWORD、QWORD或TBYTE。  G" j. x$ T) S% @
说明:LABEL伪指令提供了另一种定义标号或变量名的方法,但它并不为符号名分配存储空间 。. e" G. T( w0 e8 p% |
4.段定义语句
& ]: S! s$ ^& _, G) S8086/8088的存储器是分段的,因此使用段定义语句来组织程序和利用存储器。常用的段定义伪/ n" u% e8 X1 }+ S3 r% c7 j( G
指令有:SEGMENT、ENDS、ASSUME、ORG、PAGE、PUBLIC、TITLE、SUBTTL等。
4 R$ {$ ^( a0 a5 @(1)SEGMENT和ENDS
% r1 X  P# V- R9 h& sSEGMENT和ENDS语句将汇编语言源程序分成段。% _6 g; h( w% r3 l# B
格式:- d. l- K( _1 o
段名 SEGMENT[定位类型][组合类型][‘类别’]0 U& P" l" c: L# a, n7 i9 L- s
! I" I: j9 }4 V: w( M5 j. D: \* G' e; d
语句段
) O% M" ?: B/ n6 Q9 [" ^5 v, r, e! }6 V8 W$ f( Z; M+ a2 h
段名 ENDS
$ i4 j1 J: P3 o) X( o" |1 f$ ]说明:段名是由自己指定的为该段起的名字。定位类型、组合类型是给段名的属性,用来指出汇编程序为该段分配的存储器的起始地址;类别名则指出段的类别。用方括号括起来的项可以缺省。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2012-7-31 20:55:18 | 显示全部楼层

2011年计算机三级考试PC技术考试要点(15)

①定位类型
; z7 _) q0 U0 y2 U8 Q+ k, f, y用于指定该段地址中的5种可供选择段起点的边界类型,如下表所示。* X; v5 Z& M4 ~
定位类型
* B. m( P  g& Y! v7 ^7 K定位类型 含 义
; C, @# Y- j% |9 n. b0 F2 gBYTE(字节) 段的起始地址可以任意
% Z) u# M. d- L) o8 T% eWORD(字)
; l- @8 m8 V# q3 l段的起始地址必须为偶数,即该地址的最低二进制位应为0
9 H& G: D: |! ?2 d. @DWORD(双字) 段的起始地址必须为4的倍数,即该地址的最后2位二进制位应为0,通常总是把DWORD用于80386的32位段中
$ Q* T: j4 p! Q+ G# wPARA(节) 段的起始地址必须为16的倍数,即该地址的最后4位二进制位应为0
9 R( K, f6 ?' }: H: M1 @% H0 iPAGE(页) 段的起始地址必须为256的倍数,即该地址的最后8位二进制位应为0" m% ~6 Z: @# K' g% c; e5 t
这个类型可以为标号或变量赋予绝对地址,以便程序以标号或变量的形式存取这些存储器单元的内容。通常情况下,在AT类型的段中不定义指令或数据,只是说明一个地址结构。②组合类型3 y8 _( r. n; \" v
用来告诉连接程序LINK,本段与其他模块中同名段的组合连接关系。共有下表所示的5种可供选择的组合类型。如果此属性缺省,则表示该段是独立的,不与其他同名段发生联系,并有自己的段起始地址。$ p5 s/ g2 V6 Z( R; L
组合类型
8 v0 o% x$ G  H. s- U$ h组合类型 含 义1 L+ B  v9 d  W% I: e
PUBLIC 链接程序LINK将不同模块中具有该类型且段名相同的段连接到同一个物理存储段中,使它们公用一个段地址2 @, b' t, y. h  M% K6 [
STACK 与PUBLIC的处理方式一样,只是连接后的段为堆栈段,链接程序LINK在链接过程中自动将新段的段地址送到堆栈段寄存器SS,将新段的长度送到堆栈指针寄存器SP。如果在定义堆栈时没有将其说明为STACK类型,在这种情况下就需要在程序中用指令给堆栈段寄存器SS、堆栈指针寄存器SP置值,这时链接程序LINK会给出一个警告信息4 y4 F7 k8 c8 `6 l+ R$ ~2 z/ `
COMMON 产生一个覆盖段。链接程序LINK为该类型的同名段指定相同的段地址。段的长度取决于最长的COMMON段的长度。段的内容为所连接的最后一个模块中COMMON段的内容及其没有被覆盖到的前面COMMON段的部分内容0 u8 E! ]: B# ~! K. V
MEMORY 链接程序LINK不单独区分MEMORY类型,它把MEMORY与PUBLIC类型同等对特。MASM程序允许使用它,主要是为了与其他支持Intel MEMOˉRY类型的连接程序兼容  ]5 ~3 @* H- I5 S' U/ g8 }
AT表达式 链接程序LINK将具有AT类型的段装在表达式值所指定的段地址边界上4 C* d6 M2 O& v! P
③类别9 B3 b, }: E) [1 N
用于控制段的存放次序。它可以是任何合法的名称,但必须用单引号括起来。连接程序LINK只使同类别的段发生关系,并将它们存放在连续的存储空间中。若“类别”选择项缺省,则表明该段类别为空。
0 I+ c6 f) U5 [(2)ASSUME语句: I# E5 {7 p# U; _9 c; \0 O
格式:ASSUME 段寄存器:段名[,段寄存器:段名,]8 Z+ m( J) l* z6 R9 {& M
功能:告诉汇编程序,程序的段结构和在各种指令执行时访问哪一段。段寄存器只能是CS、SS、DS、ES中的一个,段名是由伪指令SEGMENT/ENDS语句中定义的段名。注意:9 p4 Y2 f7 e; v1 G& p
●代码段寄存器CS只能用于有程序的段。代码段寄存器CS所对应的段名必须在该语句之前有定义,因此,ASSUME语句一般都设置于代码段内,放在段定义语句之后。
* {0 b3 K8 r+ Z! {0 \6 z●堆栈段寄存器SS只能与堆栈段相对应。6 L- P& o. @4 f) D6 q
●ASSUME语句是说明性语句,除主程序的代码段及最后一个椎栈段外,其余段寄存器的初值均由用户在程序中设置。
4 t9 `5 Y) @( y& Z(3)组定义伪指令 GROUP
+ h: P5 v8 }8 }$ t格式:组名GROUP 段名[,段名,……]
' L2 `9 m0 G1 g8 O0 f功能:将GROUP定义符后指定的所有段分配在一个64KB的物理存储器段中,并赋予该段一个名字———组名。说明:8 o  y( ]9 D( U5 x" \
●组名是用户自己定义的名字,是指出组的起始地址的一种符号。这个符号必须是惟一的,不能与任何标号、段名及变量名等同名。6 Y5 o; m, P2 v" {* b
●段名是用SEGMENT语句定义的或者由SEG运算符得到的段名。
# I! P1 h' s: P& @& U●组定义语句不影响各段的次序,因此组内各段不一定要连续存放,但它们都必须包含在64KB物理存储器段中。/ X$ g# C" t6 z/ e% t6 ~
●当源程序结构需要多个逻辑段时,使用该语句可节省段寄存器。
$ |; A6 _% T8 o+ S●实际应用中最好是让代码段为一组,堆栈段为一组,数据段为一组或两组,但组中各段所占用的内存储器的总量不超过64KB。: H' B" G' L( R; C; ~7 I
(4)指定地址伪指令 ORG格式:ORG 表达式! D- l: w+ U8 x' [
ORG $+偏移地址
5 T, S  k& Q4 d$ R$ t. y功能:指定该语句之后程序段或数据块的起始地址的偏移量,即语句表达式的值作为起始地址,连续存放程序和数据,直到下一个ORG语句为止。
# ~+ M8 m: ]9 m: L% x6 R( l5.过程定义伪指令
" s$ y* T* {% Y- v  q" D  l在程序设计中,常把具有一定功能的程序段设计成为一个过程。过程是程序的一部分,它可以被程序调用。每次可调用一个过程,当过程中的指令执行完后,控制返回调用它的地方。过程定义语句的格式:
& V" F& K$ a: P" K过程名 PROC [NEAR或FAR]" g9 ?- d' M6 ^

2 g: [2 ]% P( U& E9 M  q) g(语句)
! t" N, Q. H6 ~% c6 H┇ RET. Y! u* R" g2 W5 s9 {7 C/ U
过程名 ENDP说明:; e! G5 n0 i8 }& d
●过程名是给过程起的名字,调用过程时,过程名起标号的作用。
% X6 `8 l8 s5 H; f; G●伪指令PROC和ENDP必须成对出现,限定一个过程,并说明该过程是NEAR过程还是FAR过程。
% Q$ l' D( |% o# m1 U+ k●在宏汇编中,过程调用和从过程返回使用CALL和RET。, h5 y. v% S% g7 q0 X
●有两种调用方式:段内调用和交*调用。如果以用段内CALL指令调用过程则必须用段内RET指令返回,这样的过程是NEAR过程,用段交*CALL指令调用过程,则必须做段交*RET指令返回,这样的过程是FAR过程。( L1 x5 o; t4 \
●在一个过程中可以有多于一个的RET指令,并且过程中最后一条指令可以不是RET,但必须是一条转移过程中某处的转移指令。
+ J; F8 K. [0 h& |8 K- [0 @●主程序和子程序都可以作为一个过程。+ M! I/ @$ p" Y/ S3 U3 F
6.结束语句6 g& y2 k% E" I3 M9 @
格式:END 表达式
) M- I" e5 D$ I! X功能:结束整个源程序。9 o0 r' a0 p3 T; M' B; [- Q$ n
说明:表达式必须产生一个存储器地址。这个地址是当程序执行时,程序第一条要执行指令的地址。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2012-7-31 20:55:19 | 显示全部楼层

2011年计算机三级考试PC技术考试要点(15)

7.列表伪指令语句
- ]; w7 E. q& P+ O, {* j为使源程序的.LST文件满足用户的某些要求,宏汇编专门设置了一组列表伪指令。
! W. t0 b( N7 X$ s0 G# m(1)格式控制伪指令
/ M5 t* n$ A' k. S* E6 z格式控制伪指令有PAGE,TITLE和SUBTTL。①PAGE
* @8 N, F# L% |- ?一般为程序的第一语句,它指定汇编程序所产生的列表文件每页的行数和每行的字符数。格式:PAGE 参数1,参数2
+ N0 ^1 q8 H; [1 i1 b/ g说明:参数1表示每页行数,参数2表示每行字符数。②TITLE
+ R9 M7 i7 q& {6 p( I7 g6 A( b6 R用来为程序指定一标题,以后的列表文件会在每页第一行打印这个标题。格式:TITLE 正文③SUBTTL
5 g: J) r& n8 a) r用于为程序指定一个小标题,打印在每一页的标题之后。格式:SUBTTL 正文1 o0 q- R# N- g  r3 V" c
(2)列表控制伪指令
9 ]/ y# x: M  B, B7 H. _% P列表控制伪指令很多,主要有:, |( n  P1 {, G5 x! u- [. D5 Y9 u
①.LALL,.SALL和.XALL这是针对宏指令的伪指令。格式:.LALL/.SALL/.XALL说明:
9 }7 D! B% P* G4 X8 S●.LALL 伪指令用于对所有宏汇编列出完整的文本。. R1 g5 j' @+ W3 _, D5 U
●.SALL 伪指令用于删除宏指令所产生的所有列表。' u0 u3 K1 y4 C
●.XALL 只将宏扩展中产生目的代码的源程序列表。
" T- S. x# L- _②.LIST和.XLIST格式:.LIST/.XLIST说明:
- w7 n: Q" Z; V) X" Z●.LIST 是默认伪指令,对所有源程序进行列表直到遇到.XLIST伪指令止。
9 L5 p" `5 H/ C3 l9 D! b●.XLST 对所有源程序不产生列表直到遇到.LIST伪指令为止。上述伪指令只用于汇编产生.LST文件时起作用。& \& ^: P. @/ i
8.模块定义伪指令和通信伪指令+ @6 I9 F5 i# \. m# O2 V
在程序设计中,可以将一个复杂的程序分成若干个程序模块,每个模块在物理上和逻辑上都是相对独立的,可对它们分别进行编写和调试。即对所有模块汇编完后,再由链接装配程序LINK连接成一个完整的可执行程序。模块定义和通信指令则是实现模块划分、命名及不同模块中数据共享等的说明和记号。* }0 m) o5 V3 Q$ `4 R  {
(1)模块定义语句/ s4 F" T( M' Q, v5 P( u) V1 Y
模块定义使用NAME和ENDD两条伪指令。语句格式:
: z+ J; p/ a+ INAME 模块名 (语句)ENDD 表达式说明:
3 B) R5 S( d8 M1 ^  Y" V* O●模块名是任选的为本次汇编产生的目的模块所起的名字,是NAME的操作数。
: O7 y: Z4 K( ^, }# `●ENDD表示源程序到此结束。同时,在主模块中ENDD后允许有表达式,其他它模块只书写END。( w& C" X2 a9 U/ T
(2)PUBLIC伪指令: {6 j3 h; ^  o8 t
该伪指令定义可供其他模块引用的符号。格式:PUBLIC 符号表
8 U7 g: h0 P/ O+ {) F( M3 g' @7 j说明:符号表的各项用逗号隔开,符号可以是符号常量、变量、标号或过程名。" [1 U4 B! F. F& z4 E; W2 C
(3)EXTRN伪指令
2 t: [  H3 y, Q8 }+ S* Z# d5 p, JEXTRN伪指令的功能是用于声明当前模块使用的哪些标识符在其他模块内定义。
* h& J6 t+ T6 ?格式:EXTRN 符号:类型[,符号:类型,……]
$ ^9 Q5 K0 g' v8 v8 M# [, _说明:符号可以是符号常量、变量、标号或过程名;类型可以是BYTE、WORD、DWORD、NEAR、FAR和ABS。各项由逗号隔开。/ q* S( v2 g/ S! \3 q8 R
(二)高级汇编伪指令语句1.结构和记录' _% U9 f/ W, _" y6 a; m& o  V
(1)结构( C, {; Z: @4 y
①结构类型数据定义伪指令- a8 I% c  h/ K8 f; M
80x86宏汇编使用伪指令STRUC和ENDS建立一种结构类型的数据,然后通过结构类型数据的预置,便可方便地访问结构中的各数据项,而不需要对操作数地址表达式进行繁锁的计算。 结构类型数据定义的格式: 结构名 STRUC
6 O+ E8 ~0 k/ V8 Y6 h1 A& p/ {+ |' I) u7 _9 ]1 N; |
字段名 数据定义伪指令定义符 表达式2 l% c, {  n4 C% f0 @' X. f

2 T  P) r: p! S8 G结构名 ENDS
4 C) n) u9 e: ?3 c3 ?: I( [说明:结构类型数据是用STRUC和ENDS括起来的数据定义语句序列,这时数据定义语句中的符号称为字段名。注意:
7 Q4 Q. q2 a/ j8 L! y●定义结构时,STRUC和ENDS必须成对出现,缺一不可。4 g% `, f# F9 C: [3 L) s
●结构名是为结构起的名字,是任意选定的。. ?: C; o% Q' p* s$ i
●同时在同一结构定义中,字段名不得重名。. D& `1 x# i! H: x' F9 c
②结构变量说明与赋初值
' W2 k' u2 g4 L( M结构类型数据的定义只是告诉汇编程序已存在这样一种形式的变量,还必须对结构进行存储分配和预置后才能真正产生结构数据的变量。结构类型数据预置的格式:2 i: M9 o8 Q+ V( q$ |# ?
结构变量名 结构名 《字段值表》说明:( g. ~. G, L; P5 \. d& ~
●DATAMAX和DATATXN是结构变量名。; Q% Y' c+ {. @% _# s+ F1 e
●结构变量名是任意的,由程序员自行设定。
( E2 x& d6 t  U. F" |●结构变量名与具体的存储空间和数据相联系,在程序中可直接引用。. I: ?2 O" z$ B7 m$ V; }  ]
●字段值表用来给结构变量赋初值,字段值必须用尖括号括起来,其排列顺序和类型应该与结构定义时的各字段相一致,各字段值之间用逗号隔开。如果采用定义结构时的初值,则仅写一个逗号;若所有字段采用定义时的初值,则仅写一对尖括号。
( U5 d$ _7 Y1 Z注意:并不是所有的字段都可以重新赋初值,只有一项数据的字段可重新赋值。在程序中引用结构变量,可直接写结构变量名:引用结构变量的某一字段时,要采用下述格式:结构变量名。字段名7 ]; Z' x% S% r  l- y+ n
(2)记录* }( g& j) b7 n1 y
记录是一种处理按位计算信息的数据类型。记录定义的格式:" n: p0 M  r/ S' F3 c
记录名 RECORD 字段名:宽度[=表达式][,……]说明:  _7 l$ ^) m: F7 ]8 k" ?
●记录名和字段名必须具有惟一性;
+ s2 I: Q* ?, c, Z: j+ G2 S4 O●宽度表示字段所占的位数(1~16位),如果各字段的宽度和大于8位,那么汇编程序按字处理,否则按字节处理。若总值数少于8位或16位,则所有字段都右对齐到字或字节的最低有效位置。表达式赋给相应字段的初值,是可选择的。9 _( K' @; {1 r( b
●记录的各字段宽度之和不得大于16位。记录也必须经过预置才能产生记录类型数据变量,才能真正占有内存。记录预置的格式:
回复 支持 反对

使用道具 举报

 楼主| 发表于 2012-7-31 20:55:20 | 显示全部楼层

2011年计算机三级考试PC技术考试要点(15)

记录变量名 记录名 《字段值表》
6 [2 M! a0 H# y, g5 |" w说明:字段值表是赋给各字段的初值,必须用尖括号括起来,表中各项间用逗号分隔,各项顺序应与记录定义时相一致。若某字段采用时的初值,则该字段用逗号表示;若各字段均采用定义时的初值,则仅用尖括号。9 N5 R3 x/ R/ r$ i9 z, ~
对记录进行操作的专用操作符有3个,即:记录字段名,WIDTH和MASK。①记录字段名9 D* k# ]0 l( y2 q% b  L' [
这个操作符无操作数,可直接引用,它的结果是一个立即数,表示该字段的最低位移到所在记录最右边(0位)所需的移位次数。②WIDTH
' d; V% B3 {% W0 U返回记录或记录某字段的宽度。/ Q' h1 d7 m: C$ ^4 i
格式:WIDTH 记录名或记录字段名③MASK
) r* i2 z! E, G# t. {格式:MASK 记录字段名
* ~% {3 Q$ I9 v8 b2 _9 v) MMASK的结果是一个8位或16位二进制数,这个二进制数中相应于该字段的各位均是1,其余各位均是0。/ j6 ^8 r* g! o3 a" Y% u. C8 v4 o4 M/ v
记录操作符可以与运算符NOT、OR、AND、SHL、SHR配合使用。. U, U$ n* N4 s4 b6 _; D
关于记录、记录字段及记录变量的调用,由于记录有自己专用的操作符,故利用这些操作符可对记录及其字段进行操作。& j- N# m* N, p5 V0 L$ P# [
2.宏指令4 _9 c; [* ?. t
在汇编语言程序中,有的程序段有时要多次使用,为了使在源程序中不重复书写这个程序段,可以用一条宏指令来代替,在汇编时由汇编程序产生所需的代码。宏指令的使用过程是宏定义、宏调用和宏扩展。
: Z+ t9 ?. Z9 ~2 ^! n0 [(1)宏定义
9 \2 \* y( `) `宏指令的定义格式:
/ |9 ^& v" C0 n% m. z宏指令名 MACRO[形式参数]┆(宏体) ENDM说明:
; k1 {! R% T, E! l. R+ P$ s●宏指令名是给宏指令起的名字,MACRO是宏定义的定义符,ENDM是宏定义的结束符,两者必须成对出现。
/ O, R( x" Z/ L/ O0 \●MACRO和ENDM之间的指令序列称为宏体,即用宏指令要代替的程序段。宏指令具有接受参数的能力,宏体中使用的形式参数必须在MACRO语句中出现。当有两个以上参数时,需用逗号隔开。9 t3 e" r* H1 d$ [3 F
●在宏指令被调用时,这些参数被给出的一些名字或数值所取代。2 b8 c+ c8 F9 S' H' J6 N8 N
(2)宏调用经过宏定义后,在源程序中的任何位置可以直接使用宏指令名,实现宏指令的调用,称为宏调用。宏调用的结果是将汇编程序翻译成该宏定义的程序段,而产生的目标代码拷贝到调用点。宏调用的格式:" s+ c6 V  Q6 p; y/ w
宏调令名(参数,……)
  L! @& y2 O3 @3 `5 F& A# v3 D9 x- Z8 _- W(3)宏扩展
. P; {* s0 V- _9 x# `+ I9 e在汇编宏指令时,宏汇编程序将宏体的指令插入到宏指令所在的位置上,并用实在参数代替形式参数,同时在插入的每一条指令前加一个“+”号,这个过程称为宏扩展。2 S7 f+ H2 }3 [1 f
(4)常用宏指令$ B1 l, Q0 Q/ s! K
80x86宏汇编中常用宏指令的格式及功能如下表所示。
2 K2 V3 L5 D+ m3 E$ ~常用宏指令$ l8 Z; C; f6 e- ^' E# z/ F) Q
名称 格式 功能
3 ]& P  D3 v: ?MACRO 宏定义伪指令
: d, ]; u# M( g4 Z' x2 |PURGE PURGE宏指令名[…]" {; ^2 Q. f% P. Q4 c, C( H
其功能是取消宏指令名的定义。一个PURGE指令可同时取消多个宏定义
5 K3 q+ k, N8 Q. A. fREPT REPT《表达式》 ┆(指令体)ENDM 其功能是重复执行指令体所包含的话句,重复次数由表达式的值确定
% f' }4 S  z7 c: c& _IRP IRP形式参量,(参数表) …(指令体)ENDM 重复执行指令体内所包含的语句。重复次数由参数表中参数的个数决定。参数表中参数必须用《》括起来,参数间用逗号分隔。每重复一次,依次用参数表中的参数代替形式参数$ {7 `  B. u$ \$ h$ @: o5 G
IRPC IRPC形式参数,字符串 ┆(指令体)ENDM 功能与IRP相同,只是用字符串代替IRP中指令中的参数表
回复 支持 反对

使用道具 举报

 楼主| 发表于 2012-7-31 20:55:21 | 显示全部楼层

2011年计算机三级考试PC技术考试要点(15)

3.重复汇编伪指令
. H$ t3 j7 v! t' a9 h这是重复汇编某一语句序列的伪指令,它可以出现在宏定义中,也可以单独出现在源程序中,注意,重复汇编是在程序汇编期间对某些语句进行重复汇编,而不是在程序运行期执行重复操作。重复汇编伪指令有以下3种形式:
. i" H  Y$ j! n6 U(1)格式1" \& T2 i  f9 X. k: G% {' N
REPT《表达式》9 l! C; A+ K$ S3 [9 R
┆ ;需重复的语句组$ Y& Y7 J. `( C  G+ R/ d8 f, k" X, V" n
ENDM
0 }; V# E0 S% j9 W这种宏指令用于重复块次数确定的伪操作,它表示按表达式所指定的次数,重复REPT和ENDM之间的语句块,表达式的取值范围是0~65535。6 M' S& `, z: w" S8 r: S
(2)格式2
3 i" {0 ~/ F: UIRP《形式参数》,《实在参数1,实在参数2,……》; \/ \& P+ T5 w2 _0 G! K  w6 `5 d2 w
┆ ;需重复的语句组
% O: E; F1 `5 jENDM4 u# Y! [) L! T- B+ i( J2 R6 H7 u
这种宏指令用于带立即数的重复伪操作。实在参数是用户指定的立即数,它的个数就是重复次数,每重复一次,就用一个实在参数替代形式参数。" a; A7 n' l( {
(3)格式3# l( J0 h3 \; k8 L2 V* P! i. t% K
IRPC形式参数,《字符串》1 B, S/ E* ~2 |$ a% T
┆ ;需重复的语句组" R6 j  ?" k  W
ENDM
* d4 O/ y6 y- ]0 R, u! J: }7 g4 J这种宏指令用于带字符串的重复伪操作,重复次数由字符串的个数确定,每次重复,依次用字符串中的一个字符替代形式参数,直到字符替代完毕为止。
: Q( n! O) t# S5 S- ]% l# w# K4.条件汇编伪指令" Y# I, P3 ^' h. E6 z
80x86宏汇编提供了条件汇编功能和条件汇编伪指令,如下表所示。: R! Z7 \! S5 [$ q8 ?9 R
条件汇编伪指令) R! M5 X( I" |8 Y, T( d1 F
IFNB《参量》7 d9 _) o0 J% ^6 F# i# B
格 式 功 能0 n; L0 `) ]- ^/ u: j
IF(表达式) 若表达式值不为0,则条件为真9 m6 L7 I4 [+ e8 e
IFE(表达式) 若条件表达式值为0,则条件为真
) `& `4 I# T# [) s, j; p$ U6 V. Q1 D% ]IF1 当汇编程序处在对源程序进行第一次扫描过程时,条件为真& ?% a, I; |0 E: ]4 s: L) Z
IF2 当汇编程序处在对源程序进行第二次扫描过程时,条件为真
% d! B' k% s  Z: D2 UIFDEF《符号》 若指定符号已被定义或由EXTRN指令进行外部说明,则条件为真( H+ p! ]7 c  R
IFNDEF《符号》 若指定符号未定义或未由EXTRN指令进行外部说明,则条件为真  k/ o( }* X0 U* Z0 I: u1 M% r% c
IFB《参量》 若参量为空格,则条件为真( |3 Z, Y5 w9 e( f1 V
B《参量》 参量不是空格时,条件为真
7 W* O, {; G+ P5 X* `IFIDN《参量1》,《参量2》 当参量1的串与参量2的串相同时,条件为真9 _+ g, l0 V5 C& ]) u+ q5 M+ k0 Y
IFIDF《参量1》,《参量2》 当参量1的串与参量2的串不同时,条件为真( P/ e8 h8 w1 a1 n; a/ `5 r, f7 E$ q
各种条件汇编语句用法的一般格式为:* L$ r  L& h+ r$ t; ]
IF ×× ARGUMENT, K; D# q, f: W$ s
《语句体1》  x# m) o/ v2 P' ]% J6 `, {+ \5 b
[ELSE] (任选)' V$ o* N* B  c/ [
《语句体2》
6 e& g1 J7 \& {" g1 b* uENDIF& c7 }9 ?/ V/ r& I( t
其中,IF××是条件伪指令,××用于区别不同种类的条件伪指令
回复 支持 反对

使用道具 举报

 楼主| 发表于 2012-7-31 20:55:22 | 显示全部楼层

2011年计算机三级考试PC技术考试要点(15)

(三)伪指令语句的增强与扩充
- v5 k6 s0 B! W4 _5 p: `1.简化段定义伪指令
- q. {* N% k# f# \(1)简化段定义伪指令:完整段定义伪指令和简化段定义伪指令。在MASM5.0以上的汇编语言版本中,既可以使用完整段定义伪指令,又可使用简化段定义伪指令;在低于MASM5.0的版本中,只能使用完整段定义伪指。
3 g9 |" |  m7 g* u7 q$ k* q9 r简化段定义伪指令如下表所示。
9 D% J' H, Z! Z) V1 S; r; c$ h简化段定义伪指令
3 W' E: b; N* u! f段语句名 伪指令格式 功 能2 p) @7 B2 T" \" d  [8 ]- ]
代码段语句 .CODE[名字] 定义一个代码段,如果有多个代码段,要用名字加以区分
3 }# i% |2 f0 a0 _" c堆栈段语句 .STACK[长度] 定义一个堆栈段,并形成堆栈段寄存器SS和堆栈指针SP的初值。(SP)=长度,如果省略长度,则(SP)=1024
. a4 W( D5 X5 p* Y0 z$ I初始化近程数据段语句 .DATA 定义一个近程数据段,当用来与高级语言程序连接时,其数据空间要赋初值
$ C+ M" s; c# ^2 @7 k/ B; X非初始化近程数据段句 .DATA? 定义一个近程数据段,当用来与高级语言程序连接时,其数据空间只能用“?”定义,表示不赋初值
2 a3 x7 ]* p; w: Z) \常数段语句 .CONST 定义一个常数段,该段是近程的,用来与高级语言程序连接, 段中数据不能改变
$ G8 N* i7 {$ w4 N7 `; U* W# p* X( [初始化远程数据段语句 .FARDARA?[名字] 定义一个远程数据段,且其数据语句的数据应赋初值,用来与高级语言程序连接
8 p; d/ y# p( b- X! ^非初始化远程数据段句 .FARDARA[名字] 定义一个远程数据段,但其数据空间不赋初值,只能用“?”定义数据,用来与高级语言程序连接/ V! X( F' Q! k. A3 J6 t3 N
(2)定义内存模式伪指令(MODEL)% \$ [( Q) B' d/ J9 ~; i. |
在使用简化段定义伪指令时,必须事先说明用户使用的内存模式。格式:MODEL 模式类型[,高级语言]功能:指定数据和代码允许使用的长度。
, b' y. f$ p  y2 i# W- t●程序中凡数据或代码的长度不大于64KB时为近程,否则为远程。近程的数据通常定义在一个段中,对应于物理存储器中的一个段,只要程序一开始将其段值设置在DS中,以后数据的访问只改变偏移值,而不必改变其段值。
8 y- ]$ I$ x. X6 \$ e% P通常总是将定义内存模式伪指令语句放在用户程序中其他简化定义伪指令语句之前。可供选择的内存模式有5类,如下表所示。当独立的汇编语言源程序不与高级语言程序连接时,多数情况下只用小模式。* r, {' y( x  N. C" a, V" Q/ z: o/ K
内存模式的类型
( p) n+ E3 A) f* p; t9 ^内存模式 说 明
/ d( D: w5 y% z0 M/ z  cSmall 小模式,程序中的数据放在64KB的数据段内,代码放在64KB的代码段中,为近程2 b" s1 L2 T- j
Medium 中模式,数据为近程,允许代码为远程& N$ ^; O8 [3 E% ^9 c2 v0 F
Compact 压缩模式,代码为近程,允许数据为远程
% o# @0 |0 t* B. C7 F( q& t* s& F1 sLarge 大模式,允许数据和代码为远程,但一个数据段不能大于64KB- }/ c; |3 w6 ^& W8 W$ o
Huge 巨型模式,允许数据和代码为远程,且数据语句所用存储空间可以大于64KB
  H5 v5 T3 {4 @1 c, {, U7 E1 H2.方式选择伪指令
; S: ^  n6 L% X7 L! c80x86汇编语言是在8086/8088汇编语言的基础上逐步发展并向上兼容的,因此在对源程序进行汇编时,汇编程序首先要区分当前的源程序是针对80x86系列的哪种微处理器而执行的,为此提供了微处理器方式选择伪指令。又因为MASM5.0中对应每种微处理机的指令系统都有一个汇编执行语句集合,简称指令集,因此微处理器方式选择伪指令,实质上也就是指令集选择伪指令。方式选择伪指令的格式和功能下表所示。) g  T  v( T* b6 T  C
方式选择伪指令的格式和功能
1 t: I  X! a0 {' f. j' t7 y0 P伪指令格式; W$ v4 U2 H& J) H! }) T( ~: {
功 能$ _7 @$ k9 f7 q+ L5 Y# Q% M
.8086  V, d" w. l# m
这是一种默认方式,它告诉汇编程序只接受8086/8088指令
. b5 a" T2 I! f# P9 I4 M* v- T.286/.286C 它告诉汇编程序只接受8086/8088指令以及80286非保护方式下的指令,用.8086可以删除该伪指令( p! J& L+ ?5 d5 R4 a
.286P 靠诉汇编程序接受8086/8088以及80286的所有指令(不仅包括保护方式下的指令,也包括非保护方式下的指令),通常只有系统设计人员才使用该伪指令,可以使用.8086伪指令删除# @3 y6 E5 v6 R/ j. k
.386/.386C 告诉汇编程序接受8086/8088指令,以及80286/80386非保护方式下的指令。在这种方式下,将禁止所有保护方式下的指令出现,否则将出错
& i1 ~$ ?# r2 {& K" o" ^& ~.386P 除具有.386/.386C功能外,还允许汇编保护方式下的80286/80386指令,通常只有系统设计人员才使用该伪指令。可以使用.8086伪指令删除2 ~8 I) }9 y: b) L
.8087 选用8087指令集,并指定实数的二进制码为IEEE格式
6 y; J% ~3 s+ V8 `.287 选用80287指令集,并指定实数的二进制码为IEEE格式
: {  P: ]' s' J9 D7 j.387 选用80387指令集,并指定实数的二进制码为IEEE格式
/ P% K% J1 Q; j$ A8 w0 J.486/.486C 允许汇编非保护方式下的80486指令。MASM6.0可以使用
+ e, v5 K# j; @9 a.486P 允许汇编80486的全部指令。MASM6.0可以使用; l4 I# h* N) b- G/ Z- \
上述伪指令语句一般放在源程序的开头
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-6-16 18:21 , Processed in 0.420900 second(s), 34 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表