《第1章基础知识.ppt》由会员分享,可在线阅读,更多相关《第1章基础知识.ppt(27页珍藏版)》请在三一文库上搜索。
1、汇编语言程序设计,授课人:顾晖 计算机科学与技术学院 计算机科学与技术系,1,计算机语言的发展,机器语言,FORTRAN BASIC COBOL PASCAL C/C+ JAVA .,2,汇编语言的特点,面向机器 具有直接和简捷的特点。 可有效地访问、控制计算机的各种硬件设备, 如磁盘、存储器、CPU、I/O端口等。 目标代码简短,占用内存少,执行速度快 可与高级语言配合使用,应用十分广泛。,3,编程实现 c =a+b,并在屏幕上显示结果。,#include “stdafx.h“ #include “stdio.h“ int main(int argc, char* argv) int a,
2、b,c; a=1; b=2; c=a+b; printf(“c=%dn“,c); return 0; ,4,data segment a db ? b db ? c db ? string db c=$ data ends code segment main proc far assume cs:code, ds:data, es:data start: push ds sub ax,ax push ax mov ax,data mov ds,ax mov es,ax,mov a,1 mov b,2 mov al,a add al,b mov c,al lea dx,string mov ah
3、,09 int 21h add c,30h mov dl,c mov ah,2 int 21h mov dl,0ah int 21h mov dl,0dh int 21h ret main endp code ends end start,汇编后的目标文件只有208字节,5,汇编语言的应用,系统程序、效率代码、I/O驱动程序 系统软件 快速处理、位处理、访问硬件设备等高效程序 高级绘图程序、视频游戏程序,6,目标及建议,目标: 了解汇编语言的特性及其编程技术, 建立起“机器”和“程序”、“空间”和 “时间”的概念。 建议: 充分注意“汇编”课实践性强的特点, 多读程序,多写程序,多上机调试程序
4、, 熟悉PC机的编程结构, 掌握汇编语言及其程序设计的基本概念、方法和技巧。,7,参考资料,1.80X86汇编语言程序设计 沈美明 温冬婵 清华大学出版社 2.IBM PC 汇编语言与程序设计 PETER ABEL 编著 第4版 清华大学出版社.PRENTICE HALL 第5版 人民邮电出版社 3. IBM PC 汇编语言与程序设计例题习题集 温冬婵 沈美明 清华大学出版社,8,第1章 基础知识,数制 数制之间的转换 二进制数和十六进制数的运算 数和字符的表示 基本逻辑运算,9,预 备 知 识,存储容量单位: 1个二进制位:bit (比特) 8个二进制位:Byte (字节) 1Byte =
5、8bit 2个字节:Word (字) 1Word = 2Byte = 16bit,10,存储容量单位(续),1KB= 1024B =210B (KiloByte) 1MB=1024KB=220B (MegaByte) 1GB=1024MB=230B (GigaByte) 1TB=1024GB=240B (TeraByte) 1PB=1024TB=250B (PetaByte) 1EB=1024PB=260B (Exa Byte) 1ZB=1024 EB=270B (ZettaByte) 1YB=1024ZB=280B (Yottabyte) 1BB=1024YB=290B (BrontoByt
6、e),11,1. 数 制,二进制: 基数为2,逢二进一 11012 = 12 3 + 12 2 + 12 0 = 1310 十六进制:基数为16,逢十六进一 1001, 0001, 1000, 0111 9 1 8 7 = 9 16 3 + 1 16 2 + 8 16 1 + 7 16 0,12,2. 数制之间的转换,二进制 十六进制 十进制 二进制 十进制 十六进制,降幂法 除法,13, 二进制 十六进制 0011 0101 1011 1111 3 5 B F 0011,0101,1011,1111B = 35BFH A 1 9 C 1010 0001 1001 1100 A19CH = 1
7、010,0001,1001,1100B,14,1011B = 23+21+20=11D 降幂法 除法 例: 27D = ? B 27 11 3 3 1 - - - - 2n 16 8 4 2 1 1 1 0 1 1 27D = 11011B, 二进制 十进制,15, 十六进制 十进制 BF3CH = 11163 +15162 +3161 +12160 = 48956D 降幂法 除法 例:399D = ? H 399 143 15 399/1624/161/16 0 - - - 16n 256 16 1 F 8 1 1 8 F 399D = 18FH,16, 算术运算 二进制数:逢二进一 借一为
8、二 加法规则 乘法规则 0 + 0 = 0 0 0 = 0 0 + 1 = 1 0 1 = 0 1 + 0 = 1 1 0 = 0 1 + 1 = 0 (进位1) 1 1 = 1,3. 运算(算术运算和逻辑运算),17,0 5 C 3 H 3 D 2 5 H 4 2 E 8 H,3 D 2 5 H 0 5 C 3 H 3 7 6 2 H,1,1,十六进制数:逢十六进一 借一为十六,18, 逻辑运算(按位操作),“与”运算(AND) “或”运算(OR) A B AB A B AB 0 0 0 0 0 0 0 1 0 0 1 1 1 0 0 1 0 1 1 1 1 1 1 1 “非”运算(NOT)
9、 “异或”运算(XOR) A A A B AB 0 1 0 0 0 1 0 0 1 1 1 0 1 1 1 0,19,例:X=00FFH Y=5555H,求Z=XY= ? X= 0000 0000 1111 1111 B Y= 0101 0101 0101 0101 B Z= 0101 0101 1010 1010 B Z=55AAH,20,4. 数和字符的表示, 计算机中正负数的表示,7 6 5 4 3 2 1 0,符号位 数值位,假设机器字长为16位:,符号位 = 0 正数 数值位 = 1 负数,15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0,假设机器字长为8位
10、:,21,数的常用表示法 原码 反码 补码 原码表示法:符号 + 绝对值 例:n = 8bit +3原码 = 0 000,0011 = 03H - 3原码 = 1 000,0011 = 83H +0原码 = 0 000,0000 = 00H - 0原码 = 1 000,0000 = 80H 0 的表示不唯一 反码表示法:正数的反码同原码,负数的反码数值位与原码相反 例:n = 8bit +5反码 = 0 000,0101 = 05H - 5反码 = 1 111,1010 = FAH +0反码 = 0 000,0000 = 00H - 0反码 = 1 111,1111 = FFH 0 的表示不唯
11、一,22,补码(Twos Complement)表示法: 正数的补码: 同原码 负数的补码:(1)写出与该负数相对应的正数的补码 (2)按位求反 (3)末位加一,23,n位二进制补码的表数范围: - 2n-1 N 2n-1-1,无符号整数的表数范围: 0 N 2n-1,24,求补运算 :对一个二进制数按位求反、末位加一 X补码 求补 -X补码 补码的加法和减法: 加法规则:X+Y补码 = X补码 + Y补码 减法规则:X-Y补码 = X补码 + -Y补码,64 (-46) 18,0100 0000 1101 0010 0001 0010,例:,25,进位和溢出 进位: 由于运算结果超出了位数,最高有效位向 前的进位,这一位自然丢失,一般不表 示结果的对错。 溢出:表示结果超出了字长允许表示的范围, 一般会造成结果出错。 例: (64) 11000000 127 01111111 64 01000000 + 1 00000001 0 1 00000000 128 10000000 进位 溢出,26, 字符的表示 ASCII码:用一个字节来表示一个字符,低7位 为字符的ASCII值,最高位一般用作 校验位。 例: A 41H a 61H 1 31H 换行 0AH 回车 0DH 空格 20H,27,
链接地址:https://www.31doc.com/p-2576857.html