宏的嵌套定义有二种方式:宏定义体内引用其它的宏和宏定义体内定义其它的宏。
1、宏定义体内引用其它的宏
在宏的定义体中又引用了其它已定义好的宏,这种宏定义方式在实际的编程过程时常会用到。如果被引用的宏还没定义的话,汇编程序将会显示出错信息。
例如:
ABSMACRO OPRD1, OPRD2
…
MOPM SUB, OPRD1, OPRD2 ;引用前面已定义的宏MOPM
…
ENDM
在定义宏ABS时,引用了前面已定义好的宏MOPM。
2、宏定义体内定义其它的宏
宏的定义体内又定义了其它宏,只有在先引用了外层的宏定义,才能引用内层的宏,这是因为,当外层宏展开后,内层宏的定义才变得有效。
这种定义方式虽然有其好的一面,但它使宏的定义更加隐蔽,削弱了程序的可读性,降低了程序的可维护性,因此,这种宏定义方式在实际的编程中很少使用。
例9.4假设有三个内存字变量Oprd1,Oprd2和Oprd3,编写宏定义实现下面功能(其中:OP是除加、减之外的二元操作):
Oprd1← Oprd2 OP Oprd3
解:
方法1:用宏嵌套定义的方式来实现
OPMMMACRONAME, OP
NAMEMACROOPRD1, OPRD2, OPRD3
PUSHAX
MOVAX, OPRD2
OPAX, OPRD3
MOVOPRD1, AX
POPAX
ENDM
ENDM
这时,如果要完成下列操作(其中:W1,W2和W3是内存字变量):
W1← W2 + W3 W1← W2 OR W3
那么,可按下列宏引用的方式来完成所需要的功能:
OPMM MADDM, ADD
1MADDMMACRO OPN1, OPN2, OPN3
1PUSHAX
1MOV AX, OPN2
1ADD AX, OPN3
1MOV OPN1, AX
1POP AX
1ENDM;宏引用语句(1):在宏扩展后将得到一个新的宏定义MADDM——把后二个内存字变量之和赋给第一个内存字变量:
OPMM MORM, OR
1MORMMACRO OPN1, OPN2, OPN3
1PUSHAX
1MOV AX, OPN2
1OR AX, OPN3
1MOV OPN1, AX
1POP AX
1ENDM;宏引用语句(2):在宏扩展后将得到另一个新的宏定义MORM——把后二个内存字变量之“逻辑或”赋给第一个内存字变量:
MADDM W1, W2, W3
1PUSHAX
1MOVAX, W2
1ORAX, W3
1MOVW1, AX
1POPAX
1ENDM;有了宏引用语句(1)和(2)所得到的宏定义,当前宏引用语句和下一条才有效,并在宏扩展时能得到相应的程序片段。
MORM W1, W2, W3
1PUSHAX
1MOV AX, W2
1OR AX, W3
1MOV W1, AX
1POP AX
1ENDM
方法2:把所要运算的指令操作符作为参数进行传递
OPMMMACROOP, OPRD1, OPRD2, OPRD3
PUSHAX
MOVAX, OPRD2
OPAX, OPRD3
MOVOPRD1, AX
POPAX
ENDM
有了上述定义之后,可按下列宏引用的方式来完成上面的“加”和“逻辑或”的功能,单击它们可显示宏扩展时所得到的程序片段:
OPMM ADD, W1, W2, W3
1PUSHAX
1MOV AX, W2
1ADD AX, W3
1MOV W1, AX [Page]
1POP AX
OPMM OR, W1, W2, W3
1PUSHAX
1MOV AX, W2
1ORAX, W3
1MOV W1, AX
1POP AX
从上面二种方法的比较来看,方法2显然要简单、直观些,程序的可读性和可维护性也要高一些。所以,通常情况下,宏定义的嵌套方式在实际编程过程中是很少使用的。 |