dplicn=学汇编的方法
 
 

   1. 学汇编的方法
 
     应该具备的条件:--微机(80X86型微机)
                    
                     --MSDOS操作系统或Win95/98的 "MS-DOS方式"
                    
                     -- 编程工具: 文本编辑器: 如 MS-DOS 的 EDIT
                                  汇编器    : 如 MASM.EXE 5.0 版本
                                  连接器    : 如 LINK.EXE
                                  二进制转换: 如 EXE2BIN.EXE       
 
     学习汇编语言实践性很强。只有经过编写大量代码才能熟练掌握。此外阅读源程序也很有帮助。
  由于汇编语言是与 CPU 芯片紧密相关的,所以必须针对某一机型,清楚地了解 CPU 芯片及其外围
  设备的硬件资料。只有这样,编写代码才能得心应手。所以有两类资料需要你去积累:一类是硬件
  方面的资料和系统软件方面的资料,另一类是算法方面的经验。其他比如汇编工具等则没有多少东
  西需要深究。   
      第一类资料,比如 各种 BIOS 中断,MS-DOS 功能调用,Windows API 库,这些可以归为系统
  软件方面;而 CPU 结构,端口定义,中断定义,总线方式等可归为硬件资料。
      第二类资料,比如排序算法,字符串查找算法等。像搜索引擎所采用的算法,能在最短的时间
  内,找出符合条件的信息,而且还带有智能性。这种查找方案包含了很科学的算法。它们都是抽象
  的东西。
      总之,学习汇编,你应该目的明确,而且目标机器明确,要解决的问题也明确。这样才能有
  的放矢,最终有所收获。
     
 
 
   2 汇编语言基础 基本指令
 
     我们学习的对象机器是 PC 机,CPU 是 Intel80x86,所以先熟悉 CPU  的大致结构。
     其实经常用到的是 CPU 的各个寄存器,其他比如引脚,内部结构等,开始时先不去管它。
 由于Intel80x86 各版本 CPU 新的与旧的保持兼容,旧的 CPU 下设计的程序无需任何修改就能在
 新的CPU 下运行。Intel 8086/8088 的 所有寄存器在后来的 新版本 CPU 中都保持。它们也是最
 基本的 CPU 寄存器。 所以主要学习 Intel 8086 CPU 的寄存器:
 
  加法器 AX (AH/AL)    乘法,除法,I/O, 快速的算术运算
  基址寄存器BX (BH/BL) 基址指针 (数据段)
  计数器CX (CH/CL)     循环,重复或位移的计数器
  数据寄存器DX (DH/DL) 乘法,除法,I/O
  源索引SI        源串和索引指针
  目标索引DI        目标串和索引指针
  基址指针BP        栈的基址指针
  栈指针SP        栈的当前位置指针
  标志<Flags>          CPU 标志
  指令指针IP        当前指令的内存位置
  代码段CS        程序代码段值
  数据段DS        程序数据段值
  栈段SS        栈操作的段值
  附加段ES        程序附加数据段的段值
 
  其中 CPU 标志寄存器各位的含义如下:
 
     FLAG: (相应的 BIT 为 1 时的含义) 
       CF    进位位          向目标操作数进位或借位
       PF    奇偶校验位      低字节校验结果为偶校验
       AF    辅助进位标志    低 4 bits 的进位或借位标志
       ZF    零标志          结果为零
       SF    负数标志        结果为负数
       TF    单步标志        (CPU)转为单步状态
       IF    中断标志        中断响应打开 (清除时关闭)
       DF    方向            字串操作默认向下(down rather than up)
       OF    溢出            结果过大或过小(for destination)
 
 
   
       汇编语言指令主要就是对上述各个寄存器的操作。下面这段代码是一个完整的 COM 型可执行
   程序文件的代码,经过编译,连接和转换后,能直接执行,结果是在彩色背景下显示一些字符。
   编译后只有204 Bytes。
  
       (你需要把这段代码完整地复制下来并另存为一个以 ASM为扩展名的文件,例如  mypro1.asm。
   然后对它进行编译连结和转换,就生成一个名为 mypro1.COM 的可执行文件。你只要在 DOS 命令行
   敲入 mypro1 加回车就能看到它的执行结果。关于如何编译连结等问题以后再说。你先可以在汇编
   工作室主页上下载简装工具,使用其中的 TOCOM.BAT [filename] 批处理即可顺利生成COM文件。)
      
       
 
       在这个例子中使用了几类指令:
 
    mov 寄存器,立即数    ;数据传输类
    mov 内存,寄存器      ;数据传输类
    push 寄存器           ;堆栈操作: 入栈
    pop 寄存器            ;堆栈操作: 出栈
    int 10H               ;10H 号 中断 (视频)
    int 21H               ;21H 号 中断 (功能调用)
 
       除了这些指令外,还看到:
 
    assume                ;假定
    offset                ;求偏量
    ORG                   ;地址定位
    byte ptr              ;字节属性
    db                    ;定义字节,内存分配
   
       在一个完整的汇编源程序中,一般包括上述两类内容,它们分别是指令和汇编伪操作,
    它们是构成源程序必不可少的成分。这些指令和汇编伪操作在用法上有许多细节,需要通
    过具体的程序举例来逐步掌握。
       
                   
        
        ;运行环境: MS-DOS 或 Windows98 的 MS-DOS 方式
        ;硬件条件: 安装有 VGA 或更新的显示适配器
        ;这是命令文件 (COM) 格式的程序结构,
        stackseg segment stack   
        stackseg ends
        codeseg segment
        assume ss:codeseg
        assume cs:codeseg
                ORG 100H           
        Entry:  mov ah,0fH                  ;取当前显示模式
                int 10H
                mov byte ptr cs:vMode,al
                mov byte ptr cs:vPage,bh
 
                mov ah,00H
                mov al,03H
                int 10H                     ;设置显示模式: 3
 
                mov ah,05
                mov al,00
                int 10H                     ;设置当前显示页: 0
 
                mov ah,06H  
                mov ch,00   
                mov cl,00   
                mov dh,24   
                mov dl,79   
                mov bh,63   
                mov al,00   
                int 10H                      ;清屏操作(用以指定色彩)
                            
               
                mov ah,06H  
                mov ch,10   
                mov cl,20   
                mov dh,15   
                mov dl,50   
                mov bh,00   
                mov al,00   
                int 10H                      ;清除指定屏幕区域(用以指定色彩)
                            
                 
                mov ah,06H  
                mov ch,09    
                mov cl,22   
                mov dh,14   
                mov dl,52   
                mov bh,79   
                mov al,00   
                int 10H                      ;清除指定屏幕区域(用以指定色彩)
                            
 
                mov ah,02
                mov dh,11
                mov dl,30
                mov bh,00
                int 10H                       ;定位光标: 11,30
 
                mov ah,09H
                mov dx,offset cs:string1
                push cs
                pop ds
                int 21H                       ;显示一串字符
 
                mov ah,02
                mov dh,13
                mov dl,30
                mov bh,00
                int 10H                        ;定位光标: 13,30
 
                mov ah,09H
                mov dx,offset cs:string2
                int 21H                        ;显示一串字符
 
                mov ah,02
                mov dh,25
                mov dl,00
                mov bh,00
                int 10H                        ;定位光标:25,00(即隐藏光标)
 
                mov ah,00
                int 16H                        ;等待键盘输入
 
                mov ah,00H
                mov al,byte ptr cs:vMode
                int 10H                        ;恢复显示模式
 
                mov ah,05
                mov al,byte ptr cs:vPage
                int 10H                        ;恢复当前显示页
 
                mov ah,02
                mov dh,24
                mov dl,00
                mov bh,00
                int 10H                        ;恢复光标: 24,00
 
                mov ah,06H  
                mov ch,00   
                mov cl,00   
                mov dh,24   
                mov dl,79   
                mov bh,07   
                mov al,00   
                int 10H                         ;清屏
                            
 
                mov ax,4c00H 
                int 21H                          ;结束程序,返回 MS-DOS 提示符
 
          String1 db 'Can you see it?$'
          String2 db 'Any key to exit$'  
          vMode   db ?
          vPage   db ?
        codeseg ends
                end Entry