锅子一直想写WIN32下得汇编博文,后来感觉不妥,还是脱离WIN API,尽量纯点,锅子用的是RadAsm,网上配置文章比较多,大家找找哦。
博文里,肯定有借鉴其他教材或高手的代码,主线想按Intel 汇编语言程序设计 为蓝本,扩展讲起。
锅子水平有限,博文里 若出现代码不妥之处,敬请高手给予 提醒和纠正,谢谢大家,闲话到这,现在开始将第一个汇编程序。
;test_01INCLUDE 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 PROCmov eax,val1add eax,val2sub eax,val3mov finalval,eaxcall DumpRegsexit
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,表示结束当前整个程序,忽略后面的代码