跟着锅子一步步学习32位汇编(1)---第一个汇编程序

时间:2022-08-30 21:45:35

锅子一直想写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
-----------------------------------------------

跟着锅子一步步学习32位汇编(1)---第一个汇编程序

让我们运行效果,寄存器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,表示结束当前整个程序,忽略后面的代码