(译)win32asm教程-6

原创 2002年03月14日 09:51:00
 

7.0条件跳转<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

Code部分,你可以看到像这样的标签:

.code

mov eax, edx
sub eax, ecx
cmp eax, 2
jz loc1
xor eax, eax
jmp loc2
loc1:
xor eax, eax
inc eax
loc2:

xor eax, eax意为:eax=0)

让我们来看看这些代码:

mov eax, edx;把edx放入eax中

sub eax, ecx;eax-ecx

cmp eax, 2

这有一条新指令:cmp。Cmp意为compare(比较)。它能比较两个值(寄存器,内存,直接数值)并设置Z-flag(零标志)。零标志很像carry,也是内部标志寄存器的一位。

Jz loc1

这也是条新的。它是条件跳转指令。Jz=jump if zero(如果设置了零标志就跳转)。Loc1是一个标记指令“xor eax,eax|inc eax”内存开始处offset的标签。因而jz loc1=如果设置了零标志,跳往位于loc1的指令。

Cmp eax, 2;如果eax=2设置零标志

Jz loc1;如果设置了零标志就跳转

=如果eax等于2,跳往位于loc1的指令

然后有jmp loc2.这也好似一个跳转,但是是一个无条件跳转:它总是执行。上面的代码就是:

if ((edx-ecx)==2)
{
eax = 1;
}
else
{
eax = 0;
}

或者Basic版:

IF (edx-ecx)=2 THEN
EAX = 1
ELSE
EAX = 0
END IF

3.  1标志寄存器

标志寄存器有一套标志。它们设不设置取决于计算或其他时间。我不会讨论它们的全部。只拣几个重要的说:

ZF(零标志)

当计算结构是零时该标志被设置(compare实际上是只设置标志不保存结构的减法)

SF(符号标志)

结构为负就设置

CF(carry标志)

Carry标志中有计算后最右的位。

OF(溢出标志)

标明一个溢出了的计算。如,结构和目标不匹配。

还有更多的标志(Parity, Auxiliary, Trap, Interrupt, Direction, IOPL, Nested Task, Resume, & Virtual Mode)但因为我们不用它们,所以我不解释。

7.2跳转系列

有一整套的条件跳转,而且它们跳转与否均取决于标志的状态。但由于大部分跳转指令有明白的名字,你甚至无需知道哪个标志要设置,例如:“如果大于等于就跳转”(jge)和“符号标志=溢出标志”一样,而“如果零就跳转”和“如果零标志=1就跳转”一样。

在下表中,“意思”指的是什么样的计算结果该跳转。“如果大于就跳转”意为:

cmp x, y

jmp 如果 x 比 y大

伪代码

意思

条件

JA

Jump if above

CF=0 & ZF=0

JAE

Jump if above or equal

CF=0

JB

Jump if below

CF=1

JBE

Jump if below or equal

CF=1 or ZF=1

JC

Jump if carry

CF=1

JCXZ

Jump if CX=0

register CX=0

JE (is the same as JZ)

Jump if equal

ZF=1

JG

Jump if greater (signed)

ZF=0 & SF=OF

JGE

Jump if greater or equal (signed)

SF=OF

JL

Jump if less (signed)

SF != OF

JLE

Jump if less or equal (signed)

ZF=1 or SF!=OF

JMP

Unconditional Jump

-

JNA

Jump if not above

CF=1 or ZF=1

JNAE

Jump if not above or equal

CF=1

JNB

Jump if not below

CF=0

JNBE

Jump if not below or equal

CF=1 & ZF=0

JNC

Jump if not carry

CF=0

JNE

Jump if not equal

ZF=0

JNG

Jump if not greater (signed)

ZF=1 or SF!=OF

JNGE

Jump if not greater or equal (signed)

SF!=OF

JNL

Jump if not less (signed)

SF=OF

JNLE

Jump if not less or equal (signed)

ZF=0 & SF=OF

JNO

Jump if not overflow (signed)

OF=0

JNP

Jump if no parity

PF=0

JNS

Jump if not signed (signed)

SF=0

JNZ

Jump if not zero

ZF=0

JO

Jump if overflow (signed)

OF=1

JP

Jump if parity

PF=1

JPE

Jump if parity even

PF=1

JPO

Jump if paity odd

PF=0

JS

Jump if signed (signed)

SF=1

JZ

Jump if zero

ZF=1

所有的跳转指令需要一个参数:要跳往的offset。

(译)win32asm实例-6

 6.0 - The tiles window图块窗口We will now create a static control which we will draw the tiles on.我们将创建...
  • taowen2002
  • taowen2002
  • 2002年03月21日 08:53
  • 1078

(译)win32asm教程-2

 3.0 asm基础知识这章将教你汇编语言的基础知识1.  1伪代码(opcodes)汇编程序是用伪代码创建的。一个伪代码是一条处理器可以理解的指令。例如:ADDAdd指令把两个数加到一起。大部分伪代...
  • taowen2002
  • taowen2002
  • 2002年03月13日 08:59
  • 980

(译)win32asm教程-3

 4.0内存这部分将解释在Windows中内存是如何管理的。3.  1Dos和win3.xx在像用于Dos和Win3.xx的16位程序中,内存被分成许多个段。这些段的大小为64kb。为了存储内存,需要...
  • taowen2002
  • taowen2002
  • 2002年03月13日 08:59
  • 964

(译)win32asm教程-4

 5.0伪代码伪代码是给处理器的指令,它实际上是原始十六进制代码的可读版。因此,汇编是最低级的编程语言。汇编中的所有东西被直接翻译为十六进制码。换句话说,你没有把高级语言翻译为低级语言的编译器上的烦恼...
  • taowen2002
  • taowen2002
  • 2002年03月13日 08:58
  • 916

(译)win32asm教程-9

 10.0 masm的优点如果你不在使用masm,你可以跳过这章并尝试着转换所有的例子,或不论如何地读一下,并试着说服自己使用masm。当然,这是你的选择。但masm真的使汇编语言更容易了。10.1 ...
  • taowen2002
  • taowen2002
  • 2002年03月15日 09:00
  • 757

(译)win32asm教程-5

 6.0 文件结构汇编源文件被分成了几个部分。这些部分是code,data,未初始化data,constants,resource和relocations,资源部分是资源文件创建的,后面会有更多的讨论...
  • taowen2002
  • taowen2002
  • 2002年03月14日 09:51
  • 799

(译)win32asm教程-8

 9.0更多的伪代码这儿有更多的伪代码TESTTest对两个参数(目标,源)执行AND逻辑操作,并根据结果设置标志寄存器。结果本身不会保存。Test用来测试一个位,例如寄存器:Test eax, 10...
  • taowen2002
  • taowen2002
  • 2002年03月15日 09:01
  • 851

(译)win32asm教程-7

 8.0关于数的一些事情在大多数的编程语言中使用整数还是浮点数只取决于变量的声明。在汇编语言中,完全的不同。浮点数的计算是由特别的伪代码和FPU协处理器(浮点单元)完成的。浮点指令将会在后面讨论。先来...
  • taowen2002
  • taowen2002
  • 2002年03月15日 09:01
  • 836

(译)Win32Asm 教程-1

Win32Asm 教程这是我的Win32Asm教程。它总是创建中,但我会不停地添加内容。通过上面的next和prev链接,你可以转到后面和前面一页。介绍先来对这个教程做个小介绍。Win32Asm不是一...
  • taowen2002
  • taowen2002
  • 2002年03月11日 09:16
  • 1448

(译)win32asm教程-11

 12.0 第一个程序是创建你的第一个程序的时候了。本章中的指导将这样组织:12.1第一步如果万事具备,你应该在你的masm同一个区上有一个win32(或win32asm)目录。为每个工程,你应该创建...
  • taowen2002
  • taowen2002
  • 2002年03月16日 18:52
  • 908
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:(译)win32asm教程-6
举报原因:
原因补充:

(最多只允许输入30个字)