将代码段的一段代码复制到指定地址,这是非常很重要的一个过程,在这里介绍一种通用的方法
一说到复制。第一个想到的就是循环,然而一说到循环第一个想到的就是loop(至少我是这样的)
因为代码翻译成机器和人之间的交流通道,就是一串串的16进制数,那么就有一种更好的指令去完成,就是串传输指令movsb
不管是loop指令还是movsb指令,都需要给cx赋值,让cx来说明循环的次数,所以问题就变为怎么获取代码的长度问题
这里介绍一种最常用的办法,就是用标号去获取代码的长度
其实很简单,就是分别在你要计算的代码的开头和结尾各加一个标号,因为指令offset可以得到标号处的偏移地址,所以用标号相减的方式就能得到代码的长度
下面举一个例子,将code中的几句代码复制到0:200的内存中去
assume cs:code
code segment
start: mov ax, cs
mov ds, ax ;让ds得到代码段的额段地址
mov ax, 0
mov es, ax ;让es得到要被复制的目的地址的段地址
mov si, offset s ;得到要复制的代码的偏移地址
mov di, 200H ;得到要被复制的指定地址的偏移地址
mov cx, offset send - offset s ;'-' 这个符号是可以被汇编语言识别的就是常数相减,这里就是得到两个标号处的位移
cld