• 第一个汇编语言程序

    汇编语言以隐晦难懂而著名,但是本教程从另一个角度来看它——它是一种几乎提供了全部信息的语言。程序员可以看到正在发生的所有事情,甚至包括 CPU 中的寄存器和标志!

    但是,在拥有这种能力的同时,程序员必须负责处理数据表示的细节和指令的格式。程序员工作在一个具有大量详细信息的层次。现在以一个简单的汇编语言程序为例,来了解其工作过程。

    程序执行两个数相加,并将结果保存在寄存器中。程序名称为 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 伪指令标记的代码和数据区,被称为段。即,程序有代码段和数据段。

更多...

加载中...