第六章 相同的功能,不同的代码

本章的代码和上一章实现的是同样的功能,但是本章采用更合理的技巧去组织代码,使代码更通用、易懂。具体代码贴在下面,

         ;代码清单6-1;文件名:c06_mbr.asm;文件说明:硬盘主引导扇区代码;创建日期:2011-4-12 22:12 jmp near startmytext db 'L',0x07,'a',0x07,'b',0x07,'e',0x07,'l',0x07,' ',0x07,'o',0x07,\'f',0x07,'f',0x07,'s',0x07,'e',0x07,'t',0x07,':',0x07number db 0,0,0,0,0start:mov ax,0x7c0                  ;设置数据段基地址 mov ds,axmov ax,0xb800                 ;设置附加段基地址 mov es,axcldmov si,mytext                 mov di,0mov cx,(number-mytext)/2      ;实际上等于 13rep movsw;得到标号所代表的偏移地址mov ax,number;计算各个数位mov bx,axmov cx,5                      ;循环次数 mov si,10                     ;除数 digit: xor dx,dxdiv simov [bx],dl                   ;保存数位inc bx loop digit;显示各个数位mov bx,number mov si,4                      show:mov al,[bx+si]add al,0x30mov ah,0x04mov [es:di],axadd di,2dec sijns showmov word [es:di],0x0744jmp near $times 510-($-$$) db 0db 0x55,0xaa

实验现象:



实验体会:

有了王爽《汇编语言》的基础,读第二部分8086模式的代码没有任何难度,有几个地方需要说明

a)

jns show 当显示完最后一个数位后, SI 的内容是零。执行 dec si 指令后,由于产生了借位,实际的运算结果是 0xffff(SI 只能容纳 16 个比特),因其最高位是“1”,故处理器将标志位 SF 置“1”,表明当前 SI 中的结果可以理解为一个负数(-1)。于是,执行 jns show 时,条件不满足,接着执行后面第 51 行的指令。

b)

jmp near $ 整个程序到此结束。为了使处理器还有事做,源程序第 53 行,是一个无限循环。 NASM编译器ᨀ供了一个标记“$”,该标记等同于标号,你可以把它看成是一个隐藏在当前行行首的标号。因此, jmp near $的意思是,转移到当前指令继续执行,它和infi: jmp near infi是一样的,没有区别,但不需要使用标号,更不必为给标号起一个有意义的名字而伤脑筋。

c)

times 510-($-$$) db 0

db 0x55,0xaa

源程序第 55 行,用于重复伪指令“db 0”若干次。重复的次数是由 510-($-$ $)得到的,除去 0x55 和 0xAA 后,剩余的主引导扇区内容是 510 字节;$是当前行的汇编地址; $ $是 NASM编译器ᨀ供的另一个标记,代表当前汇编节(段)的起始汇编地址。当前程序没有定义节或段, 就默认地自成一个汇编段,而且起始的汇编地址是 0(程序起始处)。这样,用当前汇编地址减去程序开头的汇编地址(0),就是程序实体的大小。再用 510 减去程序实体的大小,就是需要填充的字节数。就像处理器把内存划分成逻辑上的分段一样,源程序也应当按段来组织,划分成独立的代码段、数据段等。














本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/421014.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

线性表----链表

链表分为单链表,循环链表,双向链表。 1,链表 采用链式方式储存的线性表称为链表,链表是用若干地址分散的存储单元存储数据元素。必须采用附加信息表示数据元素之间的逻辑关系(逻辑上相邻结点地址-指针域)。…

第七章 比高斯更快的计算

下面这段代码的功能是在显存0xb800:0 写入“123...1005050”这个字符串,没有什么难度。 ;代码清单7-1;文件名:c07_mbr.asm;文件说明:硬盘主引导扇区代码;创建日期:2011-4-13 18:02jmp near startmessage db 123...100start:mov ax…

第8章 硬盘和显卡的访问与控制

首先声明,这一章非常重要,如果刚开始读不懂,读不下去,一定要坚持,还有读这本书的一个要求是王爽《汇编语言》看两遍,并做完所有的课后实验。这一章其实是操作系统的的加载和引导过程。其中涉及的有硬盘读写…

和不安全的Android说再见,Google为它添加新铠甲

伴随着最近被曝出的Heartbleed漏洞,安全问题再次成为网络上的热点话题。虽然Android的安全性并没有外界传言的那样脆弱,但Google还是在继续为其增加防护措施。根据Android官方博客的消息,Google最近对Android上的应用程序验证机制进行了一次升…

face-recognition库(人脸识别库)安装,使用

一,起因 1,在某hub上下载了所谓“最简单的人脸识别项目”。 2,开始了face-recognition的安装之路。 3,人脸识别在win10上的使用,识别图像上面的人脸。 二,安装face-recognition库 1,我用的都…

python入门--字符串,切片

1,python关键字 2,代码的缩进(有冒号, 下一行空格) 注意下面 3,python多行语句 4,python空行 类与函数间空行,方法与方法间空行,函数与函数空行。 5,控制台输入 下…

第9章 中断和动态时钟显示

本章的第一个代码功能是在屏幕中间实时显示时间,其实现的思想是:cpu停机---》时间每秒更新一次,每一次更新都会引起0x70中断(0x70中断的内容已经被我们更改为显示当前时间)---》中断唤醒cpu开始执行我们的中断程序知道…

linux 架构

最内层是我们的硬件,最外层是我们常用的各种应用,比如说使用firefox浏览器,打开evolution查看邮件,运行一个计算流体模型等等。硬件是我们的物质基础,而应用是我们所要奋斗的目标,但在两者之间,…

py学习,列表,判断,循环

列表 1.1 列表是什么 python 中可以通过组合一些值得到多种复合数据类型。其中最常用的是列表,可以通过方括号括起,逗号分隔的一组值(元素)得到,一个列表可以包含不同类型的元素,一个列表的元素各个类型相同…

现代软件工程讲义 3 代码规范与代码复审

请参考原址:http://www.cnblogs.com/xinz/archive/2011/11/20/2255971.html 第10章 代码规范与代码复审 在第9章中,同学们完成了WC程序,经过评比,九条的程序获得了第一名。这时,阿超说,现代软件产业经过几十…

HDU 2159 FATE (DP 二维费用背包)

题目链接 题意 : 中文题不详述。 思路 : 二维背包,dp[i][h]表示当前忍耐值为i的情况下,杀了h个怪得到的最大经验值,状态转移方程: dp[i][h] max(dp[i][h],dp[i-a[j].toler][h-1]a[j].exper) ; 1 //21592 #…

TinyFrame升级之五:全局缓存的设计及实现

在任何框架中,缓存都是不可或缺的一部分,本框架亦然。在这个框架中,我们的缓存分为两部分:内存缓存和单次请求缓存。简单说来,就是一个使用微软提供的MemoryCache做扩展,并提供全局唯一实例;另一…

问题思维导向

杨淼信息与计算机科学 跆拳道国家一级教练员 曾经tricking爱好者3 人赞同了该回答一个不算建议的建议 直接看,看到不懂的就查相应的知识(据说牛人都靠wiki活着)。 知识当有需求的时候,才会学的更快。 觉得这样做的好处是&#xff…

【Mail】telnet收发邮件过程

文章原址:http://www.cnblogs.com/h--d/p/6125993.html 作者写的真棒,按照步骤一步一步都可执行,我是在centos7服务器下进行的实验,命令完全和下面一样,注意的地方是: 1,centos7要安装telnet&a…

入门训练 Fibonacci数列

http://lx.lanqiao.org/problem.page?gpidT4入门训练 Fibonacci数列 时间限制:1.0s 内存限制:256.0MB问题描述Fibonacci数列的递推公式为:FnFn-1Fn-2,其中F1F21。 当n比较大时,Fn也非常大,现在我们想知…

python模块与包的导入

一&#xff0c;模块 1&#xff0c;下面是hello.py脚本(模块)&#xff0c;有两求Fibonacci的函数. def fib1():a, b 0, 1print(0-10内:)while a < 10:print(a, end )a, b b, a bprint()def fib2(n):a, b 0, 1L []while a < n:L.append(a)a, b b, a bprint(L)retu…

第11章 进入保护模式

对照代码重点理解一下三个要点&#xff1a; 1,从实模式到保护模式的整体过程&#xff1b; 2&#xff0c;实模式怎样安装GDT&#xff1b; 3&#xff0c;从实模式怎样过渡到安全模式&#xff1b; 4&#xff0c;安全模式怎样寻址&#xff1b; 代码如下&#xff1a; ;代码清单1…