首页
社区
课程
招聘
[旧帖] [求助]这句看不懂 0.00雪花
2007-7-12 21:29 3699

[旧帖] [求助]这句看不懂 0.00雪花

2007-7-12 21:29
3699
77BFFEE0     F64431 1D 04 test    byte ptr [ecx+esi+1D], 4                  ; ds:[003A27D5]=28 ('(')

这句看不懂了?

[CTF入门培训]顶尖高校博士及硕士团队亲授《30小时教你玩转CTF》,视频+靶场+题目!助力进入CTF世界

收藏
点赞0
打赏
分享
最新回复 (2)
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
新手向导 2007-7-12 21:49
2
0
我记得是 那个 [ECX+EDI+1D]和4做AND,标志进标志位

各位意见?
雪    币: 205
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
极度挑战 2007-7-12 22:49
3
0
test属于逻辑运算指令
功能: 执行BIT与BIT之间的逻辑运算
     测试(两操作数作与运算,仅修改标志位,不回送结果).
Test对两个参数(目标,源)执行AND逻辑操作,并根据结果设置标志寄存器,结果本身不会保存。EST AX,BX 与 AND AX,BX 命令有相同效果
语法: TEST r/m,r/m/data
影响标志: C,O,P,Z,S(其中C与O两个标志会被设为0)
运用举例:
1.Test用来测试一个位,例如寄存器:
test eax, 100b;          b后缀意为二进制
jnz  ******;             如果eax右数第三个位为1,jnz将会跳转
我是这样想的,jnz跳转的条件是ZF=0,ZF=0意味着ZF(零标志)没被置位,即逻辑与结果为1.
2.Test的一个非常普遍的用法是用来测试一方寄存器是否为空:
test ecx, ecx
jz somewhere
如果ecx为零,设置ZF零标志为1,Jz跳转
游客
登录 | 注册 方可回帖
返回