在汇编语言的程序中,标号,总是免不了的。
程序编写的长了,标号,就要有很多。

但是,在一个程序中,标号,是不能重名的。
于是,在编程时,对于标号的命名,往往要费些心思。

@@,在汇编语言中,是当作标号用的。
而且,这个标号,还可以重复使用。
这不就方便多了吗?

标号,有时是作为一段程序的名称。
其最基本的功能就是:作为转移指令、调用指令的目的地。

可是,如果在程序中,有了很多很多的 @@,可怎么区分它们呢?
方法就是:最近。

@F,就是向下转移到最近的 @@ 处;
@B,就是向上转移到最近的 @@ 处。

例如:

    MOV   CX, 8   ;循环 8 次
@@: ... ...      ;这就是一个标号
    ... ...
    ... ...      ;循环体
    ... ...
    LOOP  @B     ;向上转移到最近的@@处

又例如:

    MOV   AL, [SI]
    CMP   AL, 0
    JNZ   @F     ;向下转移到最近的@@处
    ... ...
    ... ...
@@: ... ...
    ... ...

做而论道所编写的程序,有许多标号都是使用了 @@ 的形式。
看起来很简明,而且编程也方便。

但是需要注意的是:

--用 EMU8086 编译不通过,@@ 报错。
--网上搜了一下,说是 @@ 只对于 MASM 有效。

如果实在是想用 EMU8086,你也可以自己改动一下。
把 @@、@F、@B 都改掉,即可。

比如,在某处有个 @@,你可以自己改成:XX1;
然后在其前、后都找一找,凡是转移到此处的 @F、@B,都要改成:XX1。

其它的 @@、…,也都按此方法,依次修改,即可。
改过之后,用 EMU8086 编译时,就应该不出错了。