欢迎光临
免费的PDF电子书下载网站

汇编语言:基于x86处理器(原书第7版) PDF下载

编辑推荐

汇编语言:基于x86处理器(原书第7版) PDF下载 ;

内容简介

本书是汇编语言课程的经典教材,系统介绍x86和Intel64处理器的汇编语言编程和架构。前9章为汇编语言的核心概念,包括:汇编语言基础,x86处理器架构,数据传送、寻址和算术运算,过程,条件处理,整数运算,高级过程,以及字符串和数组。本书为原书第7版,增加了部分实例程序的讨论,补充了更多的复习题和关键术语,介绍了64位编程;还有配套的网上资料,提供完整的程序清单、复习题答案和编程练习的解决方案。

作者简介

暂无

汇编语言:基于x86处理器(原书第7版) PDF下载

目录

目  录Assembly Language for x86 Processors, Seventh Edition出版者的话译者序前言第1章 基本概念 11.1 欢迎来到汇编语言的世界 11.1.1 读者可能会问的问题 21.1.2 汇编语言的应用 41.1.3 本节回顾 51.2 虚拟机概念 51.3 数据表示 71.3.1 二进制整数 71.3.2 二进制加法 81.3.3 整数存储大小 91.3.4 十六进制整数 101.3.5 十六进制加法 111.3.6 有符号二进制整数 121.3.7 二进制减法 131.3.8 字符存储 141.3.9 本节回顾 151.4 布尔表达式 161.4.1 布尔函数真值表 181.4.2 本节回顾 181.5 本章小结 191.6 关键术语 191.7 复习题和练习 201.7.1 简答题 201.7.2 算法基础 21第2章 x86处理器架构 232.1 一般概念 232.1.1 基本微机设计 232.1.2 指令执行周期 242.1.3 读取内存 252.1.4 加载并执行程序 262.1.5 本节回顾 262.2 32位x86处理器 272.2.1 操作模式 272.2.2 基本执行环境 272.2.3 x86内存管理 302.2.4 本节回顾 302.3 64位x86-64处理器 302.3.1 64位操作模式 312.3.2 基本64位执行环境 312.4 典型x86计算机组件 322.4.1 主板 322.4.2 内存 342.4.3 本节回顾 342.5 输入输出系统 342.5.1 I/O访问层次 342.5.2 本节回顾 362.6 本章小结 362.7 关键术语 372.8 复习题 38第3章 汇编语言基础 393.1 基本语言元素 393.1.1 第一个汇编语言程序 393.1.2 整数常量 403.1.3 整型常量表达式 413.1.4 实数常量 413.1.5 字符常量 423.1.6 字符串常量 423.1.7 保留字 423.1.8 标识符 433.1.9 伪指令 433.1.10 指令 443.1.11 本节回顾 463.2 示例:整数加减法 463.2.1 AddTwo程序 463.2.2 运行和调试AddTwo程序 483.2.3 程序模板 523.2.4 本节回顾 523.3 汇编、链接和运行程序 533.3.1 汇编–链接–执行周期 533.3.2 列表文件 533.3.3 本节回顾 553.4 定义数据 553.4.1 内部数据类型 553.4.2 数据定义语句 553.4.3 向AddTwo程序添加一个变量 563.4.4 定义BYTE和SBYTE数据 573.4.5 定义WORD和SWORD数据 593.4.6 定义DWORD和SDWORD数据 593.4.7 定义QWORD数据 603.4.8 定义压缩BCD(TBYTE)数据 603.4.9 定义浮点类型 613.4.10 变量加法程序 613.4.11 小端顺序 623.4.12 声明未初始化数据 623.4.13 本节回顾 633.5 符号常量 633.5.1 等号伪指令 633.5.2 计算数组和字符串的大小 643.5.3 EQU伪指令 653.5.4 TEXTEQU伪指令 663.5.5 本节回顾 663.6 64位编程 673.7 本章小结 683.8 关键术语 693.8.1 术语 693.8.2 指令、运算符和伪指令 703.9 复习题和练习 703.9.1 简答题 703.9.2 算法基础 713.10 编程练习 71第4章 数据传送、寻址和算术运算 734.1 数据传送指令 734.1.1 引言 734.1.2 操作数类型 734.1.3 直接内存操作数 744.1.4 MOV指令 754.1.5 整数的全零/符号扩展 764.1.6 LAHF和SAHF指令 774.1.7 XCHG指令 784.1.8 直接–偏移量操作数 784.1.9 示例程序(Moves) 794.1.10 本节回顾 804.2 加法和减法 814.2.1 INC和DEC指令 814.2.2 ADD指令 814.2.3 SUB指令 814.2.4 NEG指令 824.2.5 执行算术表达式 824.2.6 加减法影响的标志位 824.2.7 示例程序(AddSubTest) 854.2.8 本节回顾 864.3 与数据相关的运算符和伪指令 874.3.1 OFFSET运算符 874.3.2 ALIGN伪指令 884.3.3 PTR运算符 884.3.4 TYPE运算符 894.3.5 LENGTHOF运算符 894.3.6 SIZEOF运算符 904.3.7 LABEL伪指令 904.3.8 本节回顾 904.4 间接寻址 914.4.1 间接操作数 914.4.2 数组 914.4.3 变址操作数 924.4.4 指针 934.4.5 本节回顾 954.5 JMP和LOOP指令 954.5.1 JMP指令 964.5.2 LOOP指令 964.5.3 在Visual Studio调试器中显示数组 974.5.4 整数数组求和 984.5.5 复制字符串 984.5.6 本节回顾 994.6 64位编程 994.6.1 MOV指令 994.6.2 64位的SumArray程序 1004.6.3 加法和减法 1014.6.4 本节回顾 1024.7 本章小结 1024.8 关键术语 1044.8.1 术语 1044.8.2 指令、运算符和伪指令 1044.9 复习题和练习 1044.9.1 简答题 1044.9.2 算法基础 1064.10 编程练习 107第5章 过程 1085.1 堆栈操作 1085.1.1 运行时堆栈(32位模式) 1085.1.2 PUSH和POP指令 1105.1.3 本节回顾 1125.2 定义并使用过程 1125.2.1 PROC伪指令 1125.2.2 CALL和RET指令 1145.2.3 过程调用嵌套 1155.2.4 向过程传递寄存器参数 1165.2.5 示例:整数数组求和 1165.2.6 保存和恢复寄存器 1185.2.7 本节回顾 1195.3 链接到外部库 1195.3.1 背景知识 1195.3.2 本节回顾 1205.4 Irvine32链接库 1205.4.1 创建库的动机 1205.4.2 概述 1225.4.3 过程详细说明 1235.4.4 库测试程序 1335.4.5 本节回顾 1395.5 64位汇编编程 1395.5.1 Irvine64链接库 1395.5.2 调用64位子程序 1405.5.3 x64调用规范 1405.5.4 调用过程示例 1415.6 本章小结 1425.7 关键术语 1435.7.1 术语 1435.7.2 指令、运算符和伪指令 1435.8 复习题和练习 1435.8.1 简答题 1435.8.2 算法基础 1465.9 编程练习 146第6章 条件处理 1486.1 条件分支 1486.2 布尔和比较指令 1486.2.1 CPU状态标志 1496.2.2 AND指令 1496.2.3 OR指令 1506.2.4 位映射集 1516.2.5 XOR指令 1526.2.6 NOT指令 1536.2.7 TEST指令 1536.2.8 CMP指令 1546.2.9 置位和清除单个CPU标志位 1556.2.10 64位模式下的布尔指令 1556.2.11 本节回顾 1566.3 条件跳转 1566.3.1 条件结构 1566.3.2 Jcond指令 1566.3.3 条件跳转指令类型 1576.3.4 条件跳转应用 1596.3.5 本节回顾 1636.4 条件循环指令 1636.4.1 LOOPZ和LOOPE指令 1636.4.2 LOOPNZ和LOOPNE指令 1646.4.3 本节回顾 1646.5 条件结构 1646.5.1 块结构的IF语句 1656.5.2 复合表达式 1676.5.3 WHILE循环 1686.5.4 表驱动选择 1696.5.5 本节回顾 1716.6 应用:有限状态机 1726.6.1 验证输入字符串 1726.6.2 验证有符号整数 1726.6.3 本节回顾 1766.7 条件控制流伪指令 1766.7.1 新建IF语句 1776.7.2 有符号数和无符号数的比较 1786.7.3 复合表达式 1796.7.4 用.REPEAT和.WHILE创建循环 1816.8 本章小结 1826.9 关键术语 1836.9.1 术语 1836.9.2 指令、运算符和伪指令 1846.10 复习题和练习 1846.10.1 简答题 1846.10.2 算法基础 1866.11 编程练习 1876.11.1 测试代码的建议 1876.11.2 习题 188第7章 整数运算 1917.1 移位和循环移位指令 1917.1.1 逻辑移位和算术移位 1917.1.2 SHL指令 1927.1.3 SHR指令 1937.1.4 SAL和SAR指令 1937.1.5 ROL指令 1947.1.6 ROR指令 1957.1.7 RCL和RCR指令 1957.1.8 有符号数溢出 1967.1.9 SHLD/SHRD指令 1967.1.10 本节回顾 1987.2 移位和循环移位的应用 1987.2.1 多个双字的移位 1987.2.2 二进制乘法 1997.2.3 显示二进制位 2007.2.4 提取文件日期字段 2007.2.5 本节回顾 2017.3 乘法和除法指令 2017.3.1 MUL指令 2017.3.2 IMUL指令 2037.3.3 测量程序执行时间 2057.3.4 DIV指令 2077.3.5 有符号数除法 2087.3.6 实现算术表达式 2117.3.7 本节回顾 2127.4 扩展加减法 2127.4.1 ADC指令 2127.4.2 扩展加法示例 2137.4.3 SBB指令 2157.4.4 本节回顾 2157.5 ASCII和非压缩十进制运算 2167.5.1 AAA指令 2177.5.2 AAS指令 2187.5.3 AAM指令 2187.5.4 AAD指令 2197.5.5 本节回顾 2197.6 压缩十进制运算 2197.6.1 DAA指令 2207.6.2 DAS指令 2207.6.3 本节回顾 2217.7 本章小结 2217.8 关键术语 2227.8.1 术语 2227.8.2 指令、运算符和伪指令 2227.9 复习题和练习 2227.9.1 简答题 2227.9.2 算法基础 2247.10 编程练习 225第8章 高级过程 2278.1 引言 2278.2 堆栈帧 2278.2.1 堆栈参数 2278.2.2 寄存器参数的缺点 2288.2.3 访问堆栈参数 2308.2.4 32位调用规范 2328.2.5 局部变量 2338.2.6 引用参数 2358.2.7 LEA指令 2358.2.8 ENTER和LEAVE指令 2368.2.9 LOCAL伪指令 2388.2.10 Microsoft x64调用规范 2398.2.11 本节回顾 2398.3 递归 2398.3.1 递归求和 2408.3.2 计算阶乘 2418.3.3 本节回顾 2468.4 INVOKE、ADDR、PROC和PROTO 2468.4.1 INVOKE伪指令 2468.4.2 ADDR运算符 2478.4.3 PROC伪指令 2478.4.4 PROTO伪指令 2508.4.5 参数类别 2538.4.6 示例:交换两个整数 2538.4.7 调试提示 2548.4.8 WriteStackFrame过程 2558.4.9 本节回顾 2568.5 新建多模块程序 2568.5.1 隐藏和导出过程名 2568.5.2 调用外部过程 2578.5.3 跨模块使用变量和标号 2588.5.4 示例:ArraySum程序 2598.5.5 用Extern新建模块 2598.5.6 用INVOKE和PROTO新建模块 2628.5.7 本节回顾 2658.6 参数的高级用法(可选主题) 2658.6.1 受USES运算符影响的堆栈 2658.6.2 向堆栈传递8位和16位参数 2668.6.3 传递64位参数 2678.6.4 非双字局部变量 2688.7 Java字节码(可选主题) 2698.7.1 Java虚拟机 2698.7.2 指令集 2708.7.3 Java反汇编示例 2718.7.4 示例:条件分支 2738.8 本章小结 2748.9 关键术语 2758.9.1 术语 2758.9.2 指令、运算符和伪指令 2768.10 复习题和练习 2768.10.1 简答题 2768.10.2 算法基础 2768.11 编程练习 277第9章 字符串和数组 2799.1 引言 2799.2 字符串基本指令 2799.2.1 MOVSB、MOVSW和MOVSD 2809.2.2 CMPSB、CMPSW和CMPSD 2809.2.3 SCASB、SCASW和SCASD 2819.2.4 STOSB、STOSW和STOSD 2829.2.5 LODSB、LODSW和LODSD 2829.2.6 本节回顾 2829.3 部分字符串过程 2839.3.1 Str_compare过程 2839.3.2 Str_length过程 2849.3.3 Str_copy过程 2849.3.4 Str_trim过程 2859.3.5 Str_ucase过程 2879.3.6 字符串库演示程序 2889.3.7 Irivne64库中的字符串过程 2899.3.8 本节回顾 2919.4 二维数组 2919.4.1 行列顺序 2919.4.2 基址–变址操作数 2929.4.3 基址–变址–偏移量操作数 2949.4.4 64位模式下的基址–变址操作数 2949.4.5 本节回顾 2959.5 整数数组的检索和排序 2959.5.1 冒泡排序 2959.5.2 对半查找 2979.5.3 本节回顾 3029.6 Java字节码:字符串处理(可选主题) 3029.7 本章小结 3039.8 关键术语和指令 3049.9 复习题和练习 3049.9.1 简答题 3049.9.2 算法基础 3059.10 编程练习 305第10章 结构和宏 30810.1 结构 30810.1.1 定义结构 30810.1.2 声明结构变量 30910.1.3 引用结构变量 31010.1.4 示例:显示系统时间 31310.1.5 结构包含结构 31510.1.6 示例:醉汉行走 31510.1.7 声明和使用联合 31810.1.8 本节回顾 32010.2 宏 32010.2.1 概述 32010.2.2 定义宏 32110.2.3 调用宏 32210.2.4 其他宏特性 32310.2.5 使用本书的宏库(仅32位模式) 32610.2.6 示例程序:封装器 33210.2.7 本节回顾 33310.3 条件汇编伪指令 33310.3.1 检查缺失的参数 33310.3.2 默认参数初始值设定 33410.3.3 布尔表达式 33510.3.4 IF、ELSE和ENDIF伪指令 33510.3.5 IFIDN和IFIDNI伪指令 33610.3.6 示例:矩阵行求和 33610.3.7 特殊运算符 33910.3.8 宏函数 34210.3.9 本节回顾 34310.4 定义重复语句块 34410.4.1 WHILE伪指令 34410.4.2 REPEAT伪指令 34410.4.3 FOR伪指令 34510.4.4 FORC伪指令 34510.4.5 示例:链表 34610.4.6 本节回顾 34710.5 本章小结 34810.6 关键术语 34910.6.1 术语 34910.6.2 运算符和伪指令 34910.7 复习题和练习 34910.7.1 简答题 34910.7.2 算法基础 35010.8 编程练习 351第11章 MS-Windows编程 35411.1 Win32控制台编程 35411.1.1 背景知识 35411.1.2 Win32控制台函数 35711.1.3 显示消息框 35911.1.4 控制台输入 36111.1.5 控制台输出 36611.1.6 读写文件 36811.1.7 Irvine32链接库的文件I/O 37111.1.8 测试文件I/O过程 37311.1.9 控制台窗口操作 37511.1.10 控制光标 37811.1.11 控制文本颜色 37911.1.12 时间与日期函数 38011.1.13 使用64位Windows API 38311.1.14 本节回顾 38411.2 编写图形化的Windows应用程序 38411.2.1 必要的结构 38511.2.2 MessageBox函数 38611.2.3 WinMain过程 38711.2.4 WinProc过程 38711.2.5 ErrorHandler过程 38811.2.6 程序清单 38811.2.7 本节回顾 39111.3 动态内存分配 39111.3.1 HeapTest程序 39411.3.2 本节回顾 39711.4 x86存储管理 39711.4.1 线性地址 39811.4.2 页转换 40011.4.3 本节回顾 40111.5 本章小结 40211.6 关键术语 40311.7 复习题和练习 40311.7.1 简答题 40311.7.2 算法基础 40411.8 编程练习 404第12章 浮点数处理与指令编码 40612.1 浮点数二进制表示 40612.1.1 IEEE二进制浮点数表示 40612.1.2 阶码 40712.1.3 规格化二进制浮点数 40712.1.4 新建IEEE表示 40812.1.5 十进制小数转换为二进制实数 40912.1.6 本节回顾 41112.2 浮点单元 41112.2.1 FPU寄存器栈 41112.2.2 舍入 41312.2.3 浮点数异常 41412.2.4 浮点数指令集 41412.2.5 算术运算指令 41612.2.6 比较浮点数值 41912.2.7 读写浮点数值 42212.2.8 异常同步 42312.2.9 代码示例 42312.2.10 混合模式运算 42512.2.11 屏蔽与未屏蔽异常 42612.2.12 本节回顾 42712.3 x86指令编码 42712.3.1 指令格式 42712.3.2 单字节指令 42812.3.3 立即数送寄存器 42812.3.4 寄存器模式指令 42912.3.5 处理器操作数大小前缀 42912.3.6 内存模式指令 43012.3.7 本节回顾 43212.4 本章小结 43212.5 关键术语 43312.6 复习题和练习 43412.6.1 简答题 43412.6.2 算法基础 43412.7 编程练习 435第13章 高级语言接口 43813.1 引言 43813.1.1 通用规范 43813.1.2 .MODEL伪指令 43913.1.3 检查编译器生成的代码 44113.1.4 本节回顾 44413.2 内嵌汇编代码 44413.2.1 Visual C 中的__asm伪指令 44413.2.2 文件加密示例 44713.2.3 本节回顾 44913.3 32位汇编程序与C/C 的链接 44913.3.1 IndexOf示例 45013.3.2 调用C和C 函数 45313.3.3 乘法表示例 45413.3.4 调用C库函数 45713.3.5 目录表程序 45913.3.6 本节回顾 46113.4 本章小结 46113.5 关键术语 46213.6 复习题 46213.7 编程练习 462附录A MASM参考知识 464附录B x86指令集 483附录C “本节回顾”问题答案 510索引 527

前沿

前  言Assembly Language for x86 Processors, Seventh Edition本书介绍x86和Intel64处理器的汇编语言编程与架构,适合作为下述几类大学课程的教材: 汇编语言编程计算机系统基础计算机体系结构基础学生使用Intel或AMD处理器,用Microsoft宏汇编器(Microsoft Macro Assembler,MASM)编程,MASM运行在Microsoft Windows最新的版本上。尽管本书的初衷是作为大学生的编程教材,但它也是计算机体系结构课程的有效补充。本书广受欢迎,前几个版本已被翻译为多种语言。 重点主题 本版所含主题可以自然过渡到讲述计算机体系结构、操作系统和编写编译器的后续课程: 虚拟机概念指令集架构基本布尔运算指令执行周期内存访问和握手中断和轮询基于硬件的I/O浮点数二进制表示其他主题则专门针对x86和Intel64架构: 受保护的内存和分页实地址模式的内存分段16位中断处理MS-DOS和BIOS系统调用(中断)浮点单元架构和编程指令编码本书中的某些例子还可以用于计算机科学课程体系中的后续课程: 搜索与排序算法高级语言结构有限状态机代码优化示例第7版的新内容这一版增加了对程序示例的讨论,添加了更多的复习题和关键术语,介绍了64位编程,降低了对子程序库的依赖性。具体内容如下: 本版前面的几章现在包含了以64位CPU架构和编程为主的小节,并且还创建了子程序库的64位版本Irvine64。 修改、替换了很多复习题和练习,部分题目从章节内移动到该章末尾,且习题分为两部分:简答题和算法基础练习。后者要求学生编写一小段代码实现一个目标。 每章有一节为关键术语,列出了新的术语和概念,以及新的MASM伪指令和Intel指令。 添加了新的编程练习,删除了一些旧习题,并对一些现有的练习进行了修改。 本书对作者子程序库的依赖性大大减低。鼓励学生自己调用系统函数,并使用Visual Studio调试器单步执行程序。Irvine32和Irvine64链接库可以帮助学生处理输入/输出,但是不强制要求使用它们。 作者录制的新视频教程涵盖了本书的基本内容,并已添加到Pearson网站。 本书仍然关注其首要目标,即教授学生编写并调试机器级程序。它不能代替计算机体系结构的完整教材,但它确实在告诉学生计算机工作原理的基础上,给出了编写软件的第一手经验。我们认为,理论联系实际能让学生更好地掌握知识。在工程课程中,学生构建原型;在计算机体系结构课程中,学生应编写机器级程序。在这些课程里,学生都能获得难忘的经验,从而有信心在任何OS/面向机器的环境中工作。 保护模式编程是纸版章节(第1章~第13章)的重中之重。因此,学生需要在最新版本的Microsoft Windows环境下创建并运行32位和64位程序。其他4章是电子版,讲述16位编程。这些章包含了BIOS编程、MS-DOS服务、键盘和鼠标输入、视频编程和图形图像内容。其中一章为磁盘存储基础,还有一章为高级DOS编程技术。 子程序库 本书为学生提供了三个版本的子程序库,用于基本输入/输出、模拟、计时和其他有用的任务。Irvine32和Irvine64链接库运行于保护模式。16位版本的链接库(Irvine16.lib)运行于实地址模式,且只用于第14章~第17章。这些库的完整源代码见于配套的网站。链接库是为了使用方便,而不是为了阻止学生学习如何自行对输入–输出编程。鼓励学生创建自己的链接库。 所含软件与示例 所有示例程序均在Microsoft Visual Studio 2012下,用Microsoft Macro Assembler Version 11.0进行了验证。此外,还提供了批处理文件允许学生用Windows命令行汇编和运行应用程序。第14章中的32位C 应用程序已用Microsoft Visual C .NET测试。本书的内容更新与勘误参见配套的网站,其中包括了一些额外的编程项目,老师可以在章节结束的时候布置给学生。 总体目标本书的以下目标旨在提高学生对汇编语言相关知识的兴趣并拓展知识面: Intel和AMD处理器架构与编程;实地址模式和保护模式编程;汇编语言伪指令、宏、运算符与程序结构;编程方法,展示了如何用汇编语言创建系统级软件工具和应用程序;计算机硬件操作;汇编语言程序、操作系统和其他应用程序之间的交互作用。 本书的目标之一是帮助学生以机器级的思维方式来处理编程问题。将CPU视为交互工具,学习尽可能直接地监控其操作是很重要的。调试器是程序员最好的朋友,不仅可以捕捉错误,还可以用作学习CPU和操作系统的教学工具。我们鼓励学生探查高级语言的内部机制,并能意识到大多数编程语言都被设计为可移植的,因此,也独立于其运行的主机。除了短小的示例外,本书还有几百个可运行的程序来演示书中讲述的指令和思想。本书结尾有参考资料,包括MS-DOS中断和指令助记符指南。 背景知识 读者应至少能熟练使用一种高级语言进行编程,比如Python、Java、C或C 。本书有一章涉及C 接口,因此,如果手边有编译器将会非常有帮助。本书不仅已经用于计算机科学和管理信息系统专业课堂,而且还用于其他工程课程。 特点完整的程序清单 配套的网站包含了补充资料、学习指南,以及本书全部示例的源代码。本书还提供了丰富的链接库,其中包括30多个过程,可以简化用户输入–输出、数字处理、磁盘和文件处理,以及字符串处理。课程初期,学生可以用这个链接库来改进自己编写的程序。之后,学生可以自行编写过程并将它们添加到链接库中。 编程逻辑 本书用两章的篇幅重点介绍了布尔逻辑和位操作,并且有意识地尝试将高级编程逻辑与底层机器细节对应起来。这有助于学生创建更有效的实现,且有助于他们更好地理解编译器是如何生成目标代码的。 硬件和操作系统概念 本书前两章介绍基础硬件和数据表示概念,包括二进制数、CPU架构、状态标志和内存映射。概述硬件和以历史的角度审视Intel处理器系列可以帮助学生更好地理解其目标计算机系统。 结构化程序设计方法 从第5章开始,关注重点为过程和功能分解。同时,提供了更复杂的编程练习,要求学生在编码之前把设计作为重点。 Java字节码和Java虚拟机 第8章和第9章解释了Java字节码的基本操作,并给出了简短的演示例子。很多短示例不仅给出了反汇编字节码形式,还给出了详细的步骤解释。 磁盘存储概念 学生从硬件和软件的角度学习基于MS-Windows的磁盘存储系统的基本原理。 创建链接库 学生不仅可以自由地把自己编写的过程添加到本书链接库,还可以创建新的链接库。他们要学习用工具箱方法进行编程,并编写多个程序可以共用的代码。 宏和结构 本书用一章专门描述创建结构、联合以及宏,这些对汇编语言编程和系统编程是非常重要的。条件宏和高级运算符使得宏更加专业。 高级语言接口 本书用一章专门描述汇编语言与C和C 的接口。对于想要从事高级语言编程工作的学生而言,这是一项重要的工作技能。他们可以学习代码优化,还可以通过例子了解C 编译器是如何优化代码的。 教学辅助 所有的程序清单都在网上。同时向教师提供了测试库、复习题答案、编程练习的解决方案,以及每章的PPT。 章节说明第1章~第9章为汇编语言核心概念,需要按顺序学习。后面的章节则可以自由选择。下面的章节示意图展示了后续章节与其他章节知识之间的依赖关系。 第1章 基本概念:汇编语言的应用、基础概念、机器语言和数据表示。 第2章 x86处理器架构:基本微计算机设计、指令执行周期、x86处理器架构、Intel64架构、x86内存管理、微计算机组件、输入–输出系统。 第3章 汇编语言基础:介绍汇编语言、链接和调试、常量和变量定义。 第4章 数据传送、寻址和算术运算:简单的数据传送和算术运算指令、汇编–链接–执行周期、运算符、伪指令、表达式、JMP和LOOP指令、间接寻址。 第5章 过程:与外部链接库的链接、描述本书链接库、堆栈操作、过程的定义和使用、流程图、自顶向下的结构设计。 第6章 条件处理:布尔和比较指令、条件跳转和循环、高级逻辑结构、有限状态机。 第7章 整数运算:移位和循环移位指令及其应用、乘法和除法、扩展加法和减法、ASCII和压缩十进制运算。 第8章 高级过程:堆栈参数、局部变量、高级PROC和INVOKE伪指令、递归。 第9章 字符串和数组:字符串原语、操作字符和整数数组、二维数组、排序和检索。 第10章 结构和宏:结构、宏、条件汇编伪指令、定义重复块。 第11章 MS-Windows编程:保护模式内存管理概念、用Microsoft-Windows API显示文本和颜色,动态内存分配。 第12章 浮点数处理与指令编码:浮点数二进制表示和浮点运算。学习IA-32浮点单元编程。理解IA-32机器指令编码。 第13章 高级语言接口:参数传递规范、内嵌汇编代码、将汇编语言模块链接到C和C 程序。 附录A MASM参考知识附录B x86指令集附录C “本节回顾”问题答案下面的章节和附录由配套网站提供: 第14章 16位MS-DOS编程:内存组织、中断、函数调用、标准MS-DOS文件I/O服务。 第15章 磁盘基础知识:磁盘存储系统、扇区、簇、目录、文件分配表、处理MS-DOS错误码、驱动器和目录操作。 第16章 BIOS编程:键盘输入、视频文本、图形、鼠标编程。 第17章 高级MS-DOS编程:自定义设计段、运行时程序结构、中断处理、用I/O端口的硬件控制。 附录D BIOS和MS-DOS中断附录E “本节回顾”问题答案(第14章~第17章)教师和学生资源教师资源下面受保护的教师资源见配套网站www.pearsonhighered.com/irvine: PPT讲义教师解题手册学生资源学生通过位于www.pearsonhighered.com/irvine的出版社网站可以找到本书作者的网站链接。下述资源位于www.asmirvine.com,且不需要用访问卡: Getting Started(入门),循序渐进的完整教程,帮助学生设置Visual Studio进行汇编语言编程。 与汇编语言编程主题相关的补充读物。 本书全部示例程序的完整代码,以及作者补充链接库的源代码。 Assembly Language Workbook(汇编语言工作手册),一个交互式的工作手册,其中包括数值转换、寻址模式、寄存器使用、调试编程和浮点二进制数。内容页面是可以自定义的HTML文档,帮助文件为Windows帮助格式。 调试工具:Microsoft Visual Studio调试器用法教程。 致谢非常感谢培生教育(Pearson Education)计算机科学的执行主编Tracy Johnson,过去几年提供了友好且有益的指导。感谢Jouve公司的Pavithra Jayapaul以及培生出版社的产品编辑Greg Dulles为本书出版所做的出色工作。 早期版本特别感谢以下诸位,他们在本书早期版本中提供了极大的帮助: William Barrett,圣何塞州立大学Scott BlackledgeJames Brink,太平洋路德大学Gerald Cahill,羚羊谷学院

汇编语言:基于x86处理器(原书第7版) pdf下载声明

本pdf资料下载仅供个人学习和研究使用,不能用于商业用途,请在下载后24小时内删除。如果喜欢,请购买正版

pdf下载地址

版权归出版社和作者所有,下载链接已删除。如果喜欢,请购买正版!

链接地址:汇编语言:基于x86处理器(原书第7版)