第一个汇编语言程序
汇编语言以隐晦难懂而著名,但是本教程从另一个角度来看它——它是一种几乎提供了全部信息的语言。程序员可以看到正在发生的所有事情,甚至包括 CPU 中的寄存器和标志!
但是,在拥有这种能力的同时,程序员必须负责处理数据表示的细节和指令的格式。程序员工作在一个具有大量详细信息的层次。现在以一个简单的汇编语言程序为例,来了解其工作过程。
程序执行两个数相加,并将结果保存在寄存器中。程序名称为 AddTwo:
大家可能已经注意到了程序中包含的注释,它总是用分号开头。程序的顶部省略了一些声明,稍后会予以说明,不过从本质上说,这是一个可以用的程序。
它不会将全部信息显示在屏幕上,但是借助工具程序调试器的运行,程序员可以按一次一行代码的方式执行程序, 并查看寄存器的值。
但是与程序员可能熟悉的类型相比它们没有那么具体,比如 int、double、float 等等。这些关键字只限制大小,并不检查变量中存放的内容。记住,程序员拥有完全控制权。
顺便说一下,那些被 .code 和 .data 伪指令标记的代码和数据区,被称为段。即,程序有代码段和数据段。
但是,在拥有这种能力的同时,程序员必须负责处理数据表示的细节和指令的格式。程序员工作在一个具有大量详细信息的层次。现在以一个简单的汇编语言程序为例,来了解其工作过程。
程序执行两个数相加,并将结果保存在寄存器中。程序名称为 AddTwo:
main PROC mov eax, 5 ;将数字 5 送入 eax 寄存器 add eax, 6 ;eax 寄存器加 6 INVOKE ExitProcess, 0 ;程序结束 main ENDP现在按照一次一行代码的方法来仔细查看这段程序:
- 第 1 行开始 main 程序(主程序),即程序的入口;
- 第 2 行将数字 5 送入 eax 寄存器;
- 第 3 行把 6 加到 EAX 的值上,得到新值 11;
- 第 5 行调用 Windows 服务(也被称为函数)ExitProcess 停止程序,并将控制权交还给操作系统;
- 第 6 行是主程序结束的标记。
大家可能已经注意到了程序中包含的注释,它总是用分号开头。程序的顶部省略了一些声明,稍后会予以说明,不过从本质上说,这是一个可以用的程序。
它不会将全部信息显示在屏幕上,但是借助工具程序调试器的运行,程序员可以按一次一行代码的方式执行程序, 并查看寄存器的值。
添加一个变量
现在让这个程序变得有趣些,将加法运算的结果保存在变量 sum 中。要实现这一点,需要增加一些标记,或声明,用来标识程序的代码和数据区:.data ;此为数据区 sum DWORD 0 ;定义名为sum的变量 .code ;此为代码区 main PROC mov eax,5 ;将数字5送入而eax寄存器 add eax,6 ;eax寄存器加6 mox sum,eax INVOKE ExitProcess,0 ;结束程序 main ENDP变量 sum 在第 2 行进行了声明,其大小为 32 位,使用了关键字 DWORD。汇编语言中有很多这样的大小关键字,其作用或多或少与数据类型一样。
但是与程序员可能熟悉的类型相比它们没有那么具体,比如 int、double、float 等等。这些关键字只限制大小,并不检查变量中存放的内容。记住,程序员拥有完全控制权。
顺便说一下,那些被 .code 和 .data 伪指令标记的代码和数据区,被称为段。即,程序有代码段和数据段。