本書共分為9章,具體介紹了匯編語言基礎知識、Win32匯編語言基本組成、Win32匯編語言的編譯運行、CPU指令系統(tǒng)、FPU指令系統(tǒng)、選擇結構程序設計、循環(huán)結構程序設計、模塊化程序設計和吾愛破解軟件使用簡介等內容。先詳細介紹了匯編語言程序設計中要用到的相關理論基礎和計算機的組成與工作原理,如數值與字符的表示方法、存儲體系結構與工作原理等;再全面介紹了32位CPU指令與浮點指令;最后詳盡介紹了匯編語言程序設計的方法,使讀者可以把更多的精力用于匯編的程序設計上。本書力爭做到,初學者用C語言能實現的功能,用本書的32位匯編語言也能實現。
本書所有例子的源程序都是完整的,并有詳細的注釋,且都能在Windows XP和Windows 7環(huán)境上編譯運行通過,特別適合初學者。本書有配套的考試系統(tǒng)和相應的題庫,既可作為測評的標準化試題(單項選擇題、多項選擇題、判斷題和填空題),又可作為測評的程序設計題(程序改錯題、程序填空題和程序設計題),可按程序功能要求進行測評,也可按標準答案源程序的相似度進行模糊測評。
本書可作為應用型本科院校計算機類專業(yè)《Win32匯編語言程序設計》的教材,也可作為《計算機組成原理與匯編語言(Win32)》的教材,適合既要求有一定理論知識,又要求突出實踐的院校,尤其適合強調提高編程能力的院校和讀者。
隨著計算機技術的發(fā)展,學生要學習的課程越來越多,每門課的學時越來越少,而匯編語言從16位過渡到32位,指令越來越多,如何在有限的時間里學到盡可能多的知識,特別是如何提高匯編語言的編程能力,壓力越來越大。于是,本書作者結合多年的教學與軟件開發(fā)的經驗,編寫了本書。
本書雖詳盡介紹了CPU指令和FPU指令等,但在實際程序設計過程中,往往可能只需要掌握其中20%的指令,就能解決現實工作中80%的問題,而剩余20%的問題,可以根據具體的需要,查閱具體的指令;其中的案例也是作者根據多年教學經驗歸納、總結、設計的,文字表述也是經過再三斟酌的,插圖也是經過專門加工的。
隨著計算機技術的發(fā)展,學生要學習的課程越來越多,每門課的學時越來越少,而匯編語言從16位過渡到32位,指令越來越多,如何在有限的時間里學到盡可能多的知識,特別是如何提高匯編語言的編程能力,壓力越來越大。于是,我們結合多年的教學與軟件開發(fā)的經驗,編寫了本書。
本書雖詳盡介紹了CPU指令和FPU指令等,但并不是每條指令都需要掌握,因為實際程序設計過程中,往往可能只需要掌握其中20%的指令,就能解決現實工作中80%的問題,而剩余20%的問題,可以根據具體的需要,查閱具體的指令。因此,在教學過程中,可根據具體的情況,選修相關內容。
作者建議,本書按12個主題進行教與學,每個主題講授與訓練約3個學時,課堂測試與講評約1個學時,合計48學時。
序 號 主 題 主 要 內 容
1 數據類型 Win32匯編語言程序結構基本組成,各種數據類型數據的定義與輸入輸出
2 MASM整數+-*/% 簡單整數數據傳送指令,整數的加減乘除余,實現整數表達式的計算
3 MASM實數+-*/ 浮點數數據傳送指令,浮點數的加減乘除,實現浮點數表達式的計算
4 MASM函數 算術指令,如FSQRT、FSIN、FCOS、FABS等函數的使用
5 選擇結構 實現整數(含字符)大小和浮點數大小的比較
6 循環(huán)結構 .while和.repeat循環(huán)及LOOP循環(huán)指令,實現各種循環(huán)重復操作
7 C嵌入匯編 串操作指令結合C嵌入匯編,在C中實現各種字符串功能
8 子程序(函數) 子程序(函數)的定義與調用,實現模塊化程序設計
9 遞歸程序設計 匯編實現遞歸程序設計及C與匯編相互調用、函數重載
10 軟件破解 OD實現逆向工程,破解其他開發(fā)工具生成的.exe文件的登錄密碼
11 浮點數表示 計算機浮點數的表示等,實現浮點數與機器碼的相互轉換,其他編碼轉換
12 CPU與存儲器連接 32位CPU體系結構、存儲訪問工作原理等
通過以上12講的教學,學生在48學時下就能具有比較強的匯編編程能力,又能初步了解計算機 的組成與工作原理,因此,本教材也可作為《計算機組成原理與匯編語言(Win32)》的教材。
本書由田民格擔任主編,秦彩杰、呂良智擔任副主編。其中秦彩杰編寫第1、2、3章,田民格編寫第4、5、6章,呂良智編寫第7、8、9章和附錄。
本書配套的電子課件和源程序等資料可登錄作者的FTP下載,網址為FTP://218.5. 241.13,用戶名為tmg,密碼為123456。本書資料在masm文件夾中,其中“組成與匯編單機版.rar”是本書單機版考試系統(tǒng),根目錄下的ksxt.exe是本書網絡版考試系統(tǒng)。
為使本書篇幅不致過長,其中的案例是根據作者多年教學經驗歸納、總結、設計的,文字表述也是經過再三斟酌的,插圖也是經過專門加工的。在使用本書的過程中,若發(fā)現有任何問題,可與作者進行溝通聯系,以使本書臻于完善。作者E-mail為TmgDelphi@163.com。
編 者
第1章 匯編語言基礎知識 1
1.1 計數制 1
1.1.1 十進制(Decimal) 1
1.1.2 二進制(Binary) 1
1.1.3 八進制(Octal) 2
1.1.4 十六進制(HexaDecimal) 2
1.2 進制數間的轉換 3
1.2.1 十進制轉二進制 3
1.2.2 十進制轉八進制和十六進制 4
1.2.3 十進制轉二進制加法口算方法 4
1.2.4 十進制轉二進制減法口算方法 5
1.2.5 十進制轉二進制其他口算方法 6
1.3 計算機計量單位 6
1.3.1 計算機存儲容量計量單位 6
1.3.2 計算機時鐘周期計量單位 6
1.4 數值數據的表示 7
1.4.1 無符號整數的表示 7
1.4.2 有符號整數的表示 7
1.4.3 移碼 8
1.4.4 BCD碼 9
1.4.5 浮點數 9
1.5 字符數據的表示 12
1.5.1 ASCII碼 12
1.5.2 機內碼 12
1.5.3 Unicode 13
1.5.4 UTF-8 14
習題1 14
第2章 Win32匯編語言基本組成 16
2.1 程序結構 16
2.1.1 處理器選擇偽指令 17
2.1.2 .model偽指令 18
2.1.3 指明是否區(qū)分大小寫 18
2.1.4 要引用的頭文件和庫文件 18
2.1.5 函數原型PROTO聲明 19
2.1.6 函數原型EXTRN聲明 19
2.1.7 變量的定義及使用 20
2.1.8 數據段和代碼段的定義 21
2.1.9 注釋 22
2.1.10 指令、標號和分行 22
2.1.11 invoke偽指令調用函數 23
2.1.12 Call指令調用函數 23
2.1.13 函數調用返回值 24
2.1.14 函數的定義 24
2.1.15 局部變量的定義 26
2.1.16 程序結束 27
2.1.17 匯編結束 27
2.2 數據類型 27
2.2.1 整數 27
2.2.2 整數常量表達式 28
2.2.3 浮點數 30
2.2.4 字符和字符串 33
2.2.5 結構體 34
習題2 36
第3章 Win32匯編語言的編譯運行 40
3.1 配置編譯鏈接環(huán)境 40
3.1.1 配置VC6.0環(huán)境 41
3.1.2 MASM32的安裝 41
3.1.3 配置MASM32環(huán)境 44
3.1.4 通過注冊表配置VC和MASM32環(huán)境 44
3.2 命令提示符下編譯鏈接和運行 44
3.3 VC環(huán)境下編譯鏈接和運行 46
3.4 C/C++嵌入匯編指令 48
3.4.1 匯編指令訪問C整型變量 48
3.4.2 匯編指令讀取C整型數組元素 49
3.4.3 匯編指令寫入C字符數組 50
3.5 C程序反匯編生成匯編源程序 51
3.5.1 C程序編譯時生成匯編語言源程序 51
3.5.2 修改C程序反匯編生成的匯編源程序 52
習題3 55
第4章 CPU指令系統(tǒng) 57
4.1 系統(tǒng)結構 58
4.2 80386微處理器結構 59
4.3 CPU寄存器 61
4.3.1 16位寄存器組 61
4.3.2 32位寄存器組 61
4.3.3 標志寄存器EFlags 62
4.4 80X86處理器工作模式 64
4.5 存儲器 65
4.6 操作數尋址方式 67
4.7 數據傳送類指令 71
4.7.1 通用數據傳送MOV/MOV[SZ]X 71
4.7.2 數據交換XCHG 73
4.7.3 字節(jié)查表轉換XLAT[B] 75
4.7.4 字節(jié)反向存儲BSWAP 76
4.7.5 入棧PUSH/PUSHA[D] 76
4.7.6 出棧POP/POPA[D] 77
4.7.7 取地址LEA/L[DEFGS]S 77
4.7.8 EFlags低8位與AH傳送LAHF/SAHF 78
4.7.9 EFlags出入棧PUSHF[D]/POPF[D] 79
4.7.10 進位位CF操作CLC/STC/CMC 79
4.7.11 方向位DF操作CLD/STD 79
4.7.12 中斷允許位IF操作CLI/STI 79
4.8 整數算術運算指令 79
4.8.1 加法ADD/ADC/INC/XADD 80
4.8.2 減法SUB/SBB/DEC/NEG 82
4.8.3 乘法MUL/IMUL 82
4.8.4 除法DIV/IDIV 83
4.8.5 符號擴展CBW/CWD/CDQ 85
4.8.6 整數比較CMP/CMPXCHG[8B] 86
4.9 調整指令(實現大數運算) 87
4.9.1 數字字符加法調整AAA 87
4.9.2 數字字符減法調整AAS 89
4.9.3 二進制編碼調整為BCD碼AAM 90
4.9.4 BCD碼調整為二進制編碼AAD 90
4.9.5 BCD碼加法調整DAA 91
4.9.6 BCD碼減法調整DAS 92
4.10 邏輯運算指令 93
4.10.1 邏輯與操作AND 93
4.10.2 邏輯或操作OR 94
4.10.3 邏輯非操作NOT 94
4.10.4 邏輯異或操作XOR 94
4.10.5 邏輯比較測試TEST 95
4.11 位操作指令 96
4.11.1 算術移位SAL/SAR 96
4.11.2 邏輯移位SHL/SHR 97
4.11.3 雙精度移位SHLD/SHRD 98
4.11.4 不帶進位循環(huán)移位ROL/ROR 100
4.11.5 帶進位循環(huán)移位RCL/RCR 100
4.11.6 位掃描BSF/BSR 101
4.11.7 第i位操作BT[CRS] 103
4.12 串操作指令 104
4.12.1 重復串操作REP[E|Z|NE|NZ] 105
4.12.2 移串操作MOVS[B|W|D] 106
4.12.3 取串操作LODS[B|W|D] 108
4.12.4 存串操作STOS[B|W|D] 109
4.12.5 輸入串操作INS[B|W|D] 110
4.12.6 輸出串操作OUTS[B|W|D] 111
4.12.7 串掃描操作SCAS[B|W|D] 111
4.12.8 串比較操作CMPS[B|W|D] 112
4.13 CPU控制指令 114
4.13.1 空操作指令NOP 114
4.13.2 等待指令WAIT 115
4.13.3 暫停指令HLT 115
4.13.4 封鎖數據指令LOCK 115
4.13.5 獲得CPU信息CPUID 115
4.13.6 讀時間戳計數器RDTSC 116
習題4 117
第1章
匯編語言基礎知識
本章主要介紹數值數據和字符數據在計算機內部的表示方法,包括各種進制數及相關計量單位;數值數據詳細介紹整數和浮點數(實數)的表示方法及顯示方法,字符數據詳細介紹ASCII碼、機內碼、Unicode編碼和UTF-8編碼的表示方法及顯示方法。通過本章的學習,讀者應該完成以下學習目標:
(1)掌握十進制、二進制、十六進制的表示方法及其相互轉換方法。
(2)了解八進制和二進制口算方法。
(3)掌握無符號整數和有符號整數的表示方法。
(4)掌握移碼的表示方法以及了解BCD碼的表示方法。
(5)掌握浮點數(實數)的表示方法。
(6)了解ASCII碼常用字符的編碼規(guī)律。
(7)了解機內碼和區(qū)位碼的編碼規(guī)律及其相互轉換方法。
(8)了解Unicode和UTF-8的編碼規(guī)律及其相互轉換方法。
1.1 計 數 制
1.1.1 十進制(Decimal)
十進制用0~9共10個數碼來表示,其基數為10,運算規(guī)則為逢十進一,各位權是10i(整數部分最低位位權為100,其余各位位權從右至左指數依次增大;小數部分最高位位權為10-1,其余各位位權從左至右指數依次減。M制數后綴字母為D,一般省略,n位整數m位小數十進制數N表示如下:
N=an-1an-2…a0.a-1…a-mD
=an-1×10n-1+an-2×10n-2+…+a0×100+a-1×10-1+…+a-m×10-m
例如:
N=325.46D
=3×102+2×101+5×100+4×10-1+6×10-2
=325.46
1.1.2 二進制(Binary)
二進制用0和1兩個數碼來表示,其基數為2,運算規(guī)則為逢二進一,各位權是2i,二進制數后綴字母為B,n位整數m位小數的二進制數N表示如下:
N=an-1an-2…a0.a-1…a-mB
=an-1×2n-1+an-2×2n-2+…+a0×20+a-1×2-1+…+a-m×2-m
例如:
N=10111101.11B
=1×27+0×26+1×25+1×24+1×23+1×22+0×21+1×20+1×2-1+1×2-2
=1×128+0×64+1×32+1×16+1×8+1×4+0×2+1×1+1×0.5+1×0.25
=189.75
……