带你走进汇编的世界

本文所做的实验是用汇编实现字符串逆向排序的功能。

其实就相当于C语言中的reverse( ) 函数。

简要叙述:

将字符串 ''abcdefghij" 放到指定的内存位置,同时分配一段内存作为栈

然后将字符串入栈再出栈,以此实现字符串逆向排序功能

一下就是代码:

编译:

 

连接:

 

调试:

初始化阶段:

观察右边内存中的数据,

 入栈结束:

字符串“abcdefghij” 已经存进内存中

出栈结束:

字符串逆向排序完成。

实现原理:

       首先在内存中定义数据段和栈;

       将字符串内容放到内存中数据段和栈中;

        由于栈的特性是后进先出,所以注意出栈时数据的排位

遇到的问题:

虽然功能是成功了,但是写代码的过程中发现了些问题,实在是搞不懂。

在debug中可以编译 mov [0],ax   这句代码

但是用masm编译工具编译时就报错。报错原因是不能直接给标量赋值。

只能将代码改为  

 mov bx,0

 mov [bx],ax

用寄存器中间过渡就行。为什么在debug中编译就能通过呢?

过了几天看到书本后面的内容,现在终于搞懂了,哈。

原来debug和编译器masm对某些指令有着不同的处理。

看下面的例子

分别用debug和masm编译一下代码:

mov ax,2000

mov ds,ax

mov al,[0]

mov bl,[1]

mov cl,[2]

mov dl,[3]

masm对指令的解释:

  

debug对指令的解释:

从它们的机器码可以看出它们对形如 " mov ax,[0] “ 这类指令在解释上的不同。

可以看出debug将它解释为 "[idata]" 是一个内存单元,”idata“ 是内存单元的编译地址;

而编译器将 "[idata]"  解释为 "idata" 。

你敢不敢扫我!!!

原文出处:http://www.cnblogs.com/zhuojun

原文地址:https://www.cnblogs.com/zhuojun/p/4055560.html