锅子一直想写WIN32下得汇编博文,后来感觉不妥,还是脱离WIN API,尽量纯点,锅子用的是RadAsm,网上配置文章比较多,大家找找哦。
博文里,肯定有借鉴其他教材或高手的代码,主线想按Intel 汇编语言程序设计 为蓝本,扩展讲起。
锅子水平有限,博文里 若出现代码不妥之处,敬请高手给予 提醒和纠正,谢谢大家,闲话到这,现在开始将第一个汇编程序。
;test_01 INCLUDE irvine32.inc INCLUDELIB Irvine32.lib INCLUDELIB KERNEL32.LIB .data val1 DWORD 10000h val2 DWORD 40000h val3 DWORD 20000h .data? finalval DWORD 2 DUP(?) .code main PROC mov eax,val1 add eax,val2 sub eax,val3 mov finalval,eax call DumpRegs exit main endp END main-----------------------------------------------
让我们运行效果,寄存器EAX变成了 30000,我们用的是16进制,所以是30000h,原来EAX是多少,我们不用去管。
上面的程序 是 先赋值EAX=10000h(mov是赋值),add是相加,代表eax+30000h,下面步 sub是相减,eax=eax-10000h,最后赋值给finalval,这个是大致意思。
------------------------------------------------
细讲下
INCLUDE irvine32.inc INCLUDELIB Irvine32.lib INCLUDELIB KERNEL32.LIB ;程序在编译时, 见到 include (伪)指令就会把它指定的 inc 文件(或 asm) 文件复制到当前位置. ;inc 文件主要包含函数或常量的声明. ;lib 文件包含了动态库函数的地址信息和静态库的函数代码, 程序在链接阶段会提取这些信息或代码; ;对 DLL(动态库), 程序运行时会根据这些地址信息去调用 DLL 中的相应的函数. .data val1 DWORD 10000h val2 DWORD 40000h val3 DWORD 20000h .data? finalval DWORD 2 DUP(?) ;.data 和 .data? 这2个 是数据段,一般未初始化的数据,放在.data?,也可以放.data段,2者的区别是,.data?段 放的都是固定的数据大小, ;比如finalval,后面用了个DUP,代表 前面数字2,表示用了 2个DWORD。 ;DWORD是数据类型,其他数据类型还有BYTE,WORD,REAL 等, ;val1 DWORD 10000h 意思是声明个变量为DWORD,放在.data段,值是10000h .code ;.code代表 字面上我们就能看出是代码段的意思了。这里是程序执行的段。 main PROC ;代码段里 一个名为main的过程 call DumpRegs ;显示寄存器信息,就是之前个图,不调用就不显示那些EAX之类的了。 main endp END main ;第一句结束 procedure,第2句 END main,表示结束当前整个程序,忽略后面的代码