标题:
[分享]
汇编基础一日一学习2
[打印本页]
作者:
柔肠寸断
时间:
2009-5-17 11:05
标题:
汇编基础一日一学习2
通用寄存器:
80386有8个32位通用寄存器。。。 这8个寄存器名位eax ecx edx ebx esp ebp esi edi
这些寄存器的低16位的寄存器可以独立访问,并且把它们命名为ax cx dx bx sp bp si di 。
这些就是8086系列寄存器以前的8个16位通用寄存器。。这是为执行8086和80286代码提供了兼容的寄存
器组。ax bx cx dx 这四个带x的寄存器的高半字和低半字可以作为8位的寄存器来独立访问。例如ah ,
al ,bh 和bl ,ch和cl ,dh和dl 。
举个例子 ax = 0040h
ah 则是ax的高8位 al 则是ax的低8位
ah = 00h al = 40h
为何我们之前做免杀,通过一些编辑工具发现我们写入的确实4000。这就是因为我们是80386cpu采用低地址结尾的。
补充知识:1字=2字节
这里我出一个演示题目让大家做下。。
假如 eax=00014000H
那么 ebx=00304400H
执行 mov ax, bx
此时eax=???
正确答案是00014400H,上面我已经说了。 80386 8个通用的寄存器,这些寄存器的低16位的寄存器就是
ax bx cx ......... 这些低16位寄存器是可以独立访问的。因为这是为了兼容之前8086寄存器等而
设置的。。所以mov ax, bx
因为ax是eax寄存器的低16位 所以它的值= 4000H 而bx是ebx寄存器的低16位,所以它的值是
4400H 。
mov ax, bx 因为mov是传送指令,传送过去之前的值是将其覆盖的(而不是相加)。
所以最终 eax = 00014400H 不知道大家懂了吗。自己多思考下。 ok 接下来我给大家出几道题目。
小作业:
假如eax之前的值= 0010C510H , ebx之前的值 = 003046E2H
(1) mov bx, ax 此时ebx = ?? eax = ??
(2) mov ah, bl 此时ax = ?? eax = ??
小提示: ah寄存器是16位ax寄存器的高8位 , bl寄存器是16位bx寄存器的低8位
(3) add ax, bx 此时 eax=?? ebx = ??
小提示: add是加法指令。 例如 add ax, bx 就等于 ax = ax +bx
作者:
278835491
时间:
2009-5-18 12:30
1、ebx=0030C510H eax=001046E2H
2、ax=E210H eax=0010E210H
3、eax=00100BF2H ebx= 003046E2H
作者:
278835491
时间:
2009-5-18 12:31
怎么没有答案哈。。。。小柔。。。。。。。
(*^__^*) ……
作者:
lichun_530
时间:
2009-5-18 14:43
参观课堂!
偷偷来看
作者:
anyd2008
时间:
2009-5-18 17:47
1、ebx=0030C510H eax=001046E2H
2、ax=E210H eax=0010E210H
3、eax=00100BF2H ebx= 003046E2H
作者:
柔肠寸断
时间:
2009-5-27 09:56
(1)ebx = 0030C510H eax = 0010C510H
把eax的低16位传给ebx的低16位,传送后eax值不变
(2)mov ah, bl 此时ax = C5E2H eax = 0010C5E2H
把bx的低8位传送给ax的高8位
(3)add ax, bx 此时 eax=00110BF2H ebx =003046E2H
把eax的低16位和ebx的低16位相加,放到ax里
作者:
plantseth
时间:
2009-5-29 19:13
0030C510
0010C510
C5E2
0010C5E2
00100BF2
003046E2
哈哈 我都答对了 +10000分
作者:
zrz444
时间:
2009-5-29 20:17
学习了.不错的教程.
作者:
自在飞花
时间:
2009-6-2 21:43
假如eax之前的值= 0010C510H , ebx之前的值 = 003046E2H
(1) mov bx, ax 此时ebx = 0030C510H eax =0010C510H
(2) mov ah, bl 此时ax = E210H eax =0010E210H
小提示: ah寄存器是16位ax寄存器的高8位 , bl寄存器是16位bx寄存器的低8位
(3) add ax, bx 此时 eax=00110BF2H ebx = 003046E2
小提示: add是加法指令。 例如 add ax, bx 就等于 ax = ax +bx
有点头晕了,就三个指令是依次执行啊还是都从头执行啊。
DOS时代用debug就可以直接查看结果了,32位汇编用什么调试工具啊(这我不知道)
作者:
scien
时间:
2009-6-5 17:35
呵呵 理解了就不难做了
作者:
sjx2008
时间:
2009-6-16 13:21
继续学习ING
作者:
tiantanok
时间:
2009-7-20 17:59
学习中
作者:
cmfming
时间:
2009-11-27 10:58
这节有些不懂呀~~~
作者:
hkhs615
时间:
2009-12-17 16:14
继续学习................
作者:
iawn1989
时间:
2010-11-19 21:24
我好像算错了
作者:
kisaly
时间:
2011-8-2 12:33
哈哈,我算对了哦!谢谢斑竹
欢迎光临 【3.A.S.T】网络安全爱好者 (http://3ast.com/)
Powered by Discuz! 7.2