![單片機(jī)原理及應(yīng)用電子教案_第1頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/2/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca1.gif)
![單片機(jī)原理及應(yīng)用電子教案_第2頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/2/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca2.gif)
![單片機(jī)原理及應(yīng)用電子教案_第3頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/2/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca3.gif)
![單片機(jī)原理及應(yīng)用電子教案_第4頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/2/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca4.gif)
![單片機(jī)原理及應(yīng)用電子教案_第5頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/2/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca/1c1bc8cd-16a1-4b3b-97a3-1c47ef82adca5.gif)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、本書主要內(nèi)容本書主要內(nèi)容l單片機(jī)基礎(chǔ)知識(shí)l單片機(jī)的組成與結(jié)構(gòu)分析lMCS-51 單片機(jī)的指令系統(tǒng)l單片機(jī)的程序設(shè)計(jì)lMCS-51單片機(jī)的中斷系統(tǒng)l定時(shí)/計(jì)數(shù)器l單片機(jī)的串行通信及接口lMCS-51單片機(jī)的系統(tǒng)擴(kuò)展第第1章章 單片機(jī)概述單片機(jī)概述 單片機(jī)簡介單片機(jī)簡介 單片機(jī)發(fā)展概述單片機(jī)發(fā)展概述 單片機(jī)應(yīng)用領(lǐng)域單片機(jī)的發(fā)展趨勢(shì)MCS-51系列系列單片機(jī)簡介學(xué)習(xí)單片機(jī)技術(shù)的方法1.1 單片機(jī)簡介單片機(jī)簡介 運(yùn)算器 控制器 主存儲(chǔ)器 外存儲(chǔ)器 輸入設(shè)備 輸出設(shè)備 操作系統(tǒng) 匯編程序 裝配程序 調(diào)試程序 匯編語言 BASIC 語言 FORTRAN語言 C 語言 財(cái)務(wù)軟件 教學(xué)軟件 管理軟件 應(yīng)用軟件
2、 程序設(shè)計(jì)語言 系統(tǒng)軟件 外部設(shè)備 主機(jī) 硬件系統(tǒng) 軟件系統(tǒng) 微型計(jì)算機(jī)系統(tǒng) 單片機(jī)是單片微型計(jì)算機(jī)的簡稱單片機(jī)是單片微型計(jì)算機(jī)的簡稱單片機(jī)可以認(rèn)為是一種計(jì)算機(jī)集成芯片,采用超大規(guī)模集成技術(shù),將中央處理器(CPU)、存儲(chǔ)器(ROM、RAM)、輸入、輸出接口集成在一塊芯片上,構(gòu)成的計(jì)算機(jī)硬件系統(tǒng)。單片機(jī)的發(fā)展概況第一階段(19711976)代表Zilog公司Z80 第二階段(19761979)Intel公司MCS-48 第三階段(19791982) Intel MCS-51,Motorola 6081/2Rokwell 6501/2第四階段(19821990) MCS-96 16位第五階段(19
3、90至今) Microchip PICMotorola MC68HC等1.3 1.3 單片機(jī)的應(yīng)用領(lǐng)域單片機(jī)的應(yīng)用領(lǐng)域1. 在工業(yè)測(cè)控中的應(yīng)用2. 在智能產(chǎn)品中的應(yīng)用在計(jì)算機(jī)網(wǎng)絡(luò)與通信技術(shù)中的應(yīng)用在家用電器中的應(yīng)用3.在醫(yī)用設(shè)備領(lǐng)域中的應(yīng)用l低功耗CMOS化l微型單片化l主流與多品種共存1.4 單片機(jī)的發(fā)展趨勢(shì)單片機(jī)的發(fā)展趨勢(shì)1.5 MCS-51系列單片機(jī)簡介系列單片機(jī)簡介1.6 學(xué)習(xí)單片機(jī)技術(shù)的方法學(xué)習(xí)單片機(jī)技術(shù)的方法1.學(xué)習(xí)單片機(jī)所需的準(zhǔn)備工作 l硬件準(zhǔn)備硬件準(zhǔn)備 l軟件準(zhǔn)備軟件準(zhǔn)備l知識(shí)準(zhǔn)備知識(shí)準(zhǔn)備 l初學(xué)者推薦的軟件硬件準(zhǔn)備初學(xué)者推薦的軟件硬件準(zhǔn)備 2.學(xué)習(xí)過程與考核方法 l主要課堂學(xué)
4、習(xí)環(huán)節(jié)主要課堂學(xué)習(xí)環(huán)節(jié) l教學(xué)形式與過程教學(xué)形式與過程 l學(xué)習(xí)要求與考核方法學(xué)習(xí)要求與考核方法 1.7 不同計(jì)數(shù)制之間的轉(zhuǎn)換不同計(jì)數(shù)制之間的轉(zhuǎn)換1.7.1 1.7.1 十進(jìn)制數(shù)十進(jìn)制數(shù)一個(gè)十進(jìn)制數(shù),它的數(shù)值是由數(shù)碼0,1,2,8,9來表示的。數(shù)碼所處的位置不同,代表數(shù)的大小也不同。 例如:53478=5104+3103+4102+7101+8100,對(duì)應(yīng)于:53478萬 千 百 十 個(gè)十進(jìn)制104103102101100 1.7.2 1.7.2 二進(jìn)制數(shù)二進(jìn)制數(shù)二進(jìn)制是按“逢二進(jìn)一”的原則進(jìn)行計(jì)數(shù)的。二進(jìn)制數(shù)的基為“2”,即其使用的數(shù)碼為0、1,共兩個(gè)。二進(jìn)制數(shù)的權(quán)是以2為底的冪。 例如:10
5、110100=127+026+125+124+023+122+021+020,對(duì)應(yīng)于: 其各位的權(quán)為1,2,4,8,即以2為底的0次冪、1次冪、2次冪等。(10110100)2127+026+125+124+023+122+021+020進(jìn)制27 26252423222120 1.7.3 1.7.3 十六進(jìn)制數(shù)十六進(jìn)制數(shù)十六進(jìn)制數(shù)的基為16,即基數(shù)碼共有l(wèi)6個(gè):0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F(xiàn)。其中A,B,C,D,E,F(xiàn)分別代表值為十進(jìn)制數(shù)中的10,11,12,13,14,15。十六進(jìn)制的權(quán)為以16為底的冪。 例如:4F8E=4163+F
6、162+8161+E160=20366,對(duì)應(yīng)于:4EF8十六進(jìn)制163162161160常用計(jì)數(shù)制表示數(shù)的方法比較常用計(jì)數(shù)制表示數(shù)的方法比較 1.7.4 1.7.4 不同進(jìn)制數(shù)之間的轉(zhuǎn)換不同進(jìn)制數(shù)之間的轉(zhuǎn)換1. 十進(jìn)制數(shù)轉(zhuǎn)換成二進(jìn)制數(shù)的方法就是用2去除該十進(jìn)制數(shù),得商和余數(shù),此余數(shù)為二進(jìn)制代碼的最小有效位(LSB)或最低位的值;再用2除該商數(shù),又可得商數(shù)和余數(shù),則此余數(shù)為LSB左鄰的二進(jìn)制代碼(次低位)。依此類推,從低位到高位逐次進(jìn)行,直到商是0為止,就可得到該十進(jìn)制數(shù)的二進(jìn)制代碼。 除二取余法除二取余法 1.7.4 1.7.4 不同進(jìn)制數(shù)之間的轉(zhuǎn)換不同進(jìn)制數(shù)之間的轉(zhuǎn)換例如:將(67)10轉(zhuǎn)換
7、成二進(jìn)制數(shù),過程如下:6722331022216184220012100余數(shù)余數(shù)余數(shù)余數(shù)余數(shù)余數(shù)余數(shù)低位高位即:(67)10=(1000011)2。1.7.4 1.7.4 不同進(jìn)制數(shù)之間的轉(zhuǎn)換不同進(jìn)制數(shù)之間的轉(zhuǎn)換1. 十進(jìn)制數(shù)轉(zhuǎn)換成二進(jìn)制數(shù)的方法將已知十進(jìn)制的小數(shù)乘以2之后,可能有進(jìn)位,使整數(shù)位為1(當(dāng)該小數(shù)大于時(shí)),也可能沒有進(jìn)位,其整數(shù)位仍為零。該整數(shù)位的值為二進(jìn)制小數(shù)的最高位。再將乘積的小數(shù)部分乘以2,所得整數(shù)位的值為二進(jìn)制小數(shù)的次高位。依此類推,直到滿足精度要求或乘2后的小數(shù)部分為0為止。 乘二取整法乘二取整法 例如:將(0.625)10轉(zhuǎn)換成二進(jìn)制數(shù),其過程如下: 0.625 2 1
8、.250 0.250 2 0.500 0.500 2 1.000 整數(shù)部分為 1 就是二進(jìn)制小數(shù)的第一位為 1 整數(shù)部分為 0 就是二進(jìn)制小數(shù)的第二位為 0 整數(shù)部分為 1 就是二進(jìn)制小數(shù)的第二位為 1 即:(0.625)10=(0.101)2 1.7.4 1.7.4 不同進(jìn)制數(shù)之間的轉(zhuǎn)換不同進(jìn)制數(shù)之間的轉(zhuǎn)換2. 二進(jìn)制數(shù)轉(zhuǎn)換為十進(jìn)制數(shù)的方法將二進(jìn)制數(shù)轉(zhuǎn)換成十進(jìn)制數(shù)時(shí),只要將二進(jìn)制數(shù)各位的權(quán)乘以各位的數(shù)碼(0或1)再相加即可。例如:將(1101.1001)2制轉(zhuǎn)換成十進(jìn)制數(shù):(1101.1001)2123+122+021+120+12-1+02-2+02-3+12-48+4+0+1+0.5+0
9、+0+0.0625=(13.5625)101.7.4 1.7.4 不同進(jìn)制數(shù)之間的轉(zhuǎn)換不同進(jìn)制數(shù)之間的轉(zhuǎn)換3. 二進(jìn)制與十六進(jìn)制數(shù)之間的轉(zhuǎn)換方法二進(jìn)制數(shù)轉(zhuǎn)換成十六進(jìn)制數(shù)例如:把(101101101.1100101)2轉(zhuǎn)換成十六進(jìn)制數(shù)。1 0 1 1 0110 1.11110001 0 1 1 0110 1.11110000 0 00二進(jìn)制十六進(jìn)制二進(jìn)制16DCA.即:(101101101.1100101)2=(16D.CA)16。1.7.4 1.7.4 不同進(jìn)制數(shù)之間的轉(zhuǎn)換不同進(jìn)制數(shù)之間的轉(zhuǎn)換2)十六進(jìn)制數(shù)轉(zhuǎn)換成二進(jìn)制數(shù)將十六進(jìn)制數(shù)轉(zhuǎn)換成二進(jìn)制數(shù)時(shí),只要將每1位十六進(jìn)制數(shù)用4位相應(yīng)的二進(jìn)制數(shù)表
10、示即可完成轉(zhuǎn)換。例如:將(ECA16)16轉(zhuǎn)換成二進(jìn)制數(shù)。101 100101011100 0二進(jìn)制十六進(jìn)制ECA161 1 00即:。1.7.5 BCD1.7.5 BCD碼碼1.7.6 ASCII1.7.6 ASCII碼碼ASCII碼是一種8位代碼,最高位一般用于奇偶校驗(yàn),用其余的7位代碼來對(duì)128個(gè)字符編碼,其中32個(gè)是控制字符,96個(gè)是圖形字符。1.8 思考練習(xí)題思考練習(xí)題(1)微型計(jì)算機(jī)由哪幾部分組成?(2)什么是單片機(jī)?它與一般微型計(jì)算機(jī)在結(jié)構(gòu)上有什么區(qū)別?(3)單片機(jī)主要應(yīng)用在哪些方面?(4)將下面的一組十進(jìn)制數(shù)轉(zhuǎn)換成二進(jìn)制數(shù):567423198968(5)將下面的二進(jìn)制數(shù)轉(zhuǎn)換成十
11、進(jìn)制數(shù)和十六進(jìn)制數(shù):10110011 1010010111101001 10011110 10000101第第2章章 單片機(jī)的組成與結(jié)構(gòu)分析單片機(jī)的組成與結(jié)構(gòu)分析 MCS-51單片機(jī)的內(nèi)部結(jié)構(gòu)單片機(jī)的內(nèi)部結(jié)構(gòu) CPU的結(jié)構(gòu)和功能的結(jié)構(gòu)和功能存儲(chǔ)器的組織結(jié)構(gòu)存儲(chǔ)器的組織結(jié)構(gòu)MCS-51單片機(jī)的并行輸入輸出端口單片機(jī)的并行輸入輸出端口MCS-51 單片機(jī)的外部引腳及功能單片機(jī)的外部引腳及功能單片機(jī)指令時(shí)序單片機(jī)指令時(shí)序思考練習(xí)題思考練習(xí)題2.1 MCS-51單片機(jī)的內(nèi)部結(jié)構(gòu)單片機(jī)的內(nèi)部結(jié)構(gòu) 2.1 MCS-51單片機(jī)的內(nèi)部結(jié)構(gòu)單片機(jī)的內(nèi)部結(jié)構(gòu) 其基本特性如下: 8位CPU,含片內(nèi)振蕩器;4KB的程
12、序存儲(chǔ)器ROM;128B的數(shù)據(jù)存儲(chǔ)器RAM;64KB的外部程序存儲(chǔ)器尋址能力;64KB的外部數(shù)據(jù)存儲(chǔ)器尋址能力;32根輸入輸出(I/O)線;2個(gè)16位定時(shí)/計(jì)數(shù)器;1個(gè)全雙工異步串行口;21個(gè)特殊功能寄存器;5個(gè)中斷源,2個(gè)優(yōu)先級(jí);具有位尋址功能。2.2 CPU的結(jié)構(gòu)和功能的結(jié)構(gòu)和功能 2.2.1 2.2.1 運(yùn)算器運(yùn)算器8051單片機(jī)的運(yùn)算器由算術(shù)/邏輯運(yùn)算單元ALU、累加器A、寄存器B、暫存器1、暫存器2以及程序狀態(tài)字寄存器PSW組成。 CYACRS0RS1FOOVP圖2.2 PSW寄存器各位的標(biāo)志符號(hào)表2.1 寄存器PSW各位的功能、標(biāo)志符號(hào)與相應(yīng)的位地址2.2.2 2.2.2 控制器控
13、制器2.3 存儲(chǔ)器的組織結(jié)構(gòu)存儲(chǔ)器的組織結(jié)構(gòu)存儲(chǔ)器的功能是存儲(chǔ)信息(即程序與數(shù)據(jù))。存儲(chǔ)器是組成計(jì)算機(jī)的主要部件,目前所使用的存儲(chǔ)器以半導(dǎo)體存儲(chǔ)器為主。從功能上來劃分,半導(dǎo)體存儲(chǔ)器可分為兩大類:即只讀存儲(chǔ)器(ROM),和隨機(jī)存儲(chǔ)器(RAM)。8051單片機(jī)的控制器由指令寄存器、指令譯碼器、堆棧指針SP、程序計(jì)數(shù)器PC、數(shù)據(jù)指針DPTR、RAM地址寄存器以及16位地址緩沖器等組成。2.3.1 MCS-512.3.1 MCS-51單片機(jī)的存儲(chǔ)器結(jié)構(gòu)單片機(jī)的存儲(chǔ)器結(jié)構(gòu)0000HFFHFFFFH64KBRAM( I/O)數(shù)據(jù)存儲(chǔ)器00H7FH80H內(nèi)部RAM 專用寄存器片外片內(nèi)0000H片內(nèi)EA=10
14、000H0FFFH片外EA=00FFFHFFFFH64KBROM 4KBROM程序存儲(chǔ)器圖2.3 8051存儲(chǔ)器配置圖2.3.2 2.3.2 程序存儲(chǔ)器程序存儲(chǔ)器程序是控制計(jì)算機(jī)運(yùn)行的一系列命令。計(jì)算機(jī)能夠識(shí)別并執(zhí)行的命令是由代碼“0”和“1”組成的一組機(jī)器指令。 2.3.3 2.3.3 數(shù)據(jù)存儲(chǔ)器數(shù)據(jù)存儲(chǔ)器單片機(jī)的數(shù)據(jù)存儲(chǔ)器由可讀可寫的存儲(chǔ)器RAM組成,最多可擴(kuò)展到64KB,用于存儲(chǔ)數(shù)據(jù)。 2.3.4 MCS-512.3.4 MCS-51單片機(jī)的內(nèi)部數(shù)據(jù)存儲(chǔ)器單片機(jī)的內(nèi)部數(shù)據(jù)存儲(chǔ)器MCS-51單片機(jī)的內(nèi)部數(shù)據(jù)存儲(chǔ)器由地址00HFFH共有256個(gè)字節(jié)的地址空間組成,這256個(gè)字節(jié)的地址空間被分
15、為兩部分,其中內(nèi)部數(shù)據(jù)RAM地址為00H7FH(即0127)。 00H1FH20H2FH30H7FH0組1組2組3組位地址為 00H7FH 只能按字節(jié)尋址的RAM區(qū)既可按位也可按字節(jié)尋址的16字節(jié)(128位)4組工作寄存器每組為R0R7(也可作按字節(jié)尋址的RAM用)32字節(jié)FFHB8HB0HA8HA0H98H90H88H80HF0HE0HD0HC8H專用寄存器中的可尋址位 (93位)80H特殊功能 寄存器 128255內(nèi)部數(shù)據(jù) RAM 0127通用RAM區(qū)圖2.4 內(nèi)部數(shù)據(jù)存儲(chǔ)器地址空間1. 內(nèi)部數(shù)據(jù)RAM單元內(nèi)部數(shù)據(jù)RAM分為工作寄存器區(qū)、位尋址區(qū)、通用RAM區(qū)三個(gè)部分。 7F7E7D7C7
16、B7A797877767574737271706F6E6D6C6B6A696867666564636261605F5E5D5C5B5A595857565554535251504F4E4D4C4B4A494847464544434241403F3E3D3C3B3A393837363534333231302F2E2D2C2B2A292827262524232221201F1E1D1C1B1A191817161514131211100F0E0D0C0B0A090807060504030201003區(qū)2區(qū)1區(qū)0區(qū)07H00H0FH08H17H10H1FH18H20H21H22H23H24H25H26H
17、27H28H29H2AH2BH2CH2DH2EH2FH7FHMSBLSB圖2.5 RAM位地址(低128位在00H7FH)00H01H02H03H04H05H06H07H08H09H0AH00000111SP(07H)00H01H02H03H04H05H06H07H08H09H0AH00001000SP(08H)1010101100H01H02H03H04H05H06H07H08H09H0AH00000111SP(07H)壓棧操作:PUSH A出棧操作:POP A系統(tǒng)復(fù)位(a)系統(tǒng)復(fù)位后,未改變SP初值時(shí)的堆棧操作(設(shè)(A)=0ABH)執(zhí)行指令:MOV SP,#60H5FH60H61H62H6
18、3H64H01100000SP(60H)5FH60H61H62H63H64H01100001SP(61H)A15FH60H61H62H63H64H01100011SP(63H)A1A2壓入數(shù)據(jù)A1相繼壓入數(shù)據(jù)A2、A35FH60H61H62H63H64H01100001SP(61H)A15FH60H61H62H63H64H01100010SP(62H)A1A2彈出數(shù)據(jù)A3A3彈出數(shù)據(jù)A2彈出數(shù)據(jù)A15FH60H61H62H63H64H01100000SP(60H)(b)系統(tǒng)復(fù)位后,改變SP初值為60H時(shí)的堆棧操作圖2.6 堆棧操作示例2. 特殊功能寄存器特殊功能寄存器SFR的地址空間是80HF
19、FH。 表2.3 特殊功能寄存器的名稱、符號(hào)與地址2. 特殊功能寄存器2. 特殊功能寄存器2. 特殊功能寄存器2.4 MCS-51單片機(jī)的并行輸入輸出端口單片機(jī)的并行輸入輸出端口2.4.1 P02.4.1 P0口結(jié)構(gòu)口結(jié)構(gòu)1. P0用作通用I/O口2. P0用作地址/數(shù)據(jù)總線分時(shí)復(fù)用方式DCLQQ P0.X鎖存器MUXP0.X引腳T1T2讀引腳寫鎖存器內(nèi)部總線讀鎖存器1234地址/數(shù)據(jù)控制CVCC2.4.2 P22.4.2 P2口結(jié)構(gòu)口結(jié)構(gòu)1. P2口用作地址總線2. P2口用作通用I/O口DCLQQ P2.X鎖存器MUX讀引腳寫鎖存器內(nèi)部總線讀鎖存器12地址控制CP2.X引腳TVCCR32.
20、4.3 P32.4.3 P3口結(jié)構(gòu)口結(jié)構(gòu)2.4.4 P12.4.4 P1口結(jié)構(gòu)口結(jié)構(gòu)DCLQQ P3.X鎖存器讀引腳寫鎖存器內(nèi)部總線讀鎖存器12P3.X引腳TVCCR第二輸出功能第二輸入功能34DCLQQ P1.X鎖存器讀引腳寫鎖存器內(nèi)部總線讀鎖存器12P1.X引腳TVCCR2.5 MCS-51單片機(jī)的外部引腳及功能單片機(jī)的外部引腳及功能2.5.1 2.5.1 電源引腳電源引腳(b)雙列直插式封裝(a)方形封裝2.5.2 2.5.2 外接晶振或外部時(shí)鐘信號(hào)輸入端外接晶振或外部時(shí)鐘信號(hào)輸入端 (a)內(nèi)部振蕩器方式 (b)外部振蕩器方式圖2.12 8051單片機(jī)的振蕩器方式表2.4 按不同工藝制造
21、的單片機(jī)芯片外接振蕩器時(shí)的接法2.5.3 2.5.3 輸入輸出引腳輸入輸出引腳:通道0是一個(gè)8位漏極開路的雙向輸入輸出通道。在外接存儲(chǔ)器或者擴(kuò)展I/O接口時(shí),P0口作為復(fù)用的低8位地址總線和雙向數(shù)據(jù)總線。在不擴(kuò)展存儲(chǔ)器或者I/O接口時(shí),作為準(zhǔn)雙向輸入輸出接口。:只有一種功能,即準(zhǔn)雙向I/O口。:可作為準(zhǔn)雙向I/O口使用;但在接有片外存儲(chǔ)器或擴(kuò)展I/O接口范圍超過256B時(shí),則該口一般只能作為高8位地址總線使用。:該口除了作為準(zhǔn)雙向口外,還具有第二功能。 2.5.4 2.5.4 控制線控制線 1. ALE/2. PSEN3. EA/VPP 4. RST(a)上電復(fù)位 (b)電平開關(guān)復(fù)位圖2.13
22、 復(fù)位電路2.6 單片機(jī)指令時(shí)序單片機(jī)指令時(shí)序S1P1 P2S2P1 P2S3P1 P2S4P1 P2S5P1 P2S6P1 P2S1P1 P2S2P1 P2S3P1 P2S4P1 P2S5P1 P2S6P1 P2P2P1S1OSCALES1S2S3S4S5S6讀操作碼讀下一個(gè)操作碼(丟棄)讀下一個(gè)操作碼A:單字節(jié)單周期指令 如:INC AS1S2S3S4S5S6讀操作碼讀第2字節(jié)讀下一個(gè)操作碼B:雙字節(jié)單周期指令 如:ADD A,#dataS1S2S3S4S5S6讀操作碼讀下一個(gè)操作碼C:單字節(jié)雙周期指令 如:INC DPTRS1S2S3S4S5S6讀操作碼讀下一個(gè)操作碼D:單字節(jié)雙周期指令
23、 如:MOVX類指令讀下一個(gè)操作碼(丟棄)S1S2S3S4S5S6S1S2S3S4S5S6讀下一個(gè)操作碼(丟棄) 不取指無ALE信號(hào)不取指S1S1地址數(shù)據(jù)訪問外部存儲(chǔ)器2.7 思考練習(xí)題思考練習(xí)題(1)MCS-51單片機(jī)包含哪些主要邏輯功能部件?(2)程序狀態(tài)字寄存器PSW包含哪幾個(gè)標(biāo)志位?各位的含義是什么?各有何作用?(3)什么叫單片機(jī)?(4)MCS-51單片機(jī)的存儲(chǔ)結(jié)構(gòu)有何特點(diǎn)?(5)單片機(jī)的EA端有何作用?在8031組成的單片機(jī)應(yīng)用系統(tǒng)中,其EA端怎樣處理?為什么?(6)單片機(jī)內(nèi)部RAM分為哪幾個(gè)部分?各有何作用?(7)MCS-51單片機(jī)的堆棧SP在操作中遵循什么原則?在開機(jī)復(fù)位時(shí),其初
24、值是多少?是否可以通過程序重新設(shè)置?(8)怎樣確定和改變單片機(jī)當(dāng)前的工作寄存器組?(9)簡要說明單片機(jī)的位地址分配。(10)試畫出常用的單片機(jī)復(fù)位電路,并說明復(fù)位后各個(gè)寄存器的狀態(tài)。第3章 MCS-51單片機(jī)的指令系統(tǒng)u 匯編語言的指令格式及符號(hào)簡介匯編語言的指令格式及符號(hào)簡介 u 尋址方式u 數(shù)據(jù)傳送類指令u算術(shù)運(yùn)算類指令u邏輯運(yùn)算類指令u位操作類指令u控制轉(zhuǎn)移類指令u思考練習(xí)題 3.1 匯編語言的指令格式及符號(hào)簡介匯編語言的指令格式及符號(hào)簡介3.1.1 指令格式指令格式標(biāo)號(hào): 操作碼助記符 第一操作數(shù) ,第二操作數(shù) ,第三操作數(shù) ;注釋例如:LOOP:MOV A, #50H;(A)50H
25、DECR0;(R0)(R0)-1 DJNZ R0, LOOP;(R0)-10,則程序轉(zhuǎn)移到LOOP地址;否則順序執(zhí)行 END;結(jié)束3.1.2 本章中符號(hào)的定義本章中符號(hào)的定義3.2 尋尋 址址 方方 式式 MCS-51單片機(jī)有7種尋址方式,見表。 表3.1 7種尋址方式的比較3.2.1 立即尋址立即尋址例如:MOV A, #23H ; (A)23H,即累加器A的內(nèi)容被替換為立即數(shù)23H。0111010000100011PC操作碼立即數(shù)ACCE0H圖3.1 MOV A,#23H的執(zhí)行示意圖該指令的功能是將8位的立即數(shù)23H傳送到累加器A中。如圖所示。其中,目的操作數(shù)采用寄存器尋址,源操作數(shù)采用立
26、即尋址。3.2.2 直接尋址直接尋址直接尋址是指在指令中包含了操作數(shù)的地址,該地址直接給出了參加運(yùn)算或傳送的單元或位。直接尋址方式可訪問三種地址空間:特殊功能寄存器SFR(該空間只能采用直接尋址)。內(nèi)部數(shù)據(jù)RAM的低128個(gè)字節(jié)單元(該空間還可以采用寄存器間接尋址)。221個(gè)位地址空間。例如例如:MOV A, 40H ;把40H單元的內(nèi)容送到累加器中,即(A)(40H)。 1110010101000000PC操作碼直接地址ACCE0H40HROM內(nèi)部RAM圖3.2 MOV A,40H的執(zhí)行示意圖 3.2.3 寄存器尋址寄存器尋址 寄存器尋址是指定某一可尋址的寄存器的內(nèi)容為操作數(shù)。 例如:MOV
27、 A, R0 ;(A)(R0)該指令的功能是將R0中的數(shù)據(jù)傳送到累加器A中。源操作數(shù)與目的操作數(shù)都采用了寄存器尋址。 在MCS-51單片機(jī)中,能夠用來間接尋址的寄存器有:用戶所選定的工作寄存器組的R0、R1,堆棧指針SP和16位的數(shù)據(jù)指針DPTR。 內(nèi)部數(shù)據(jù)RAM的寄存器間接尋址采用寄存器R0、R1;外部數(shù)據(jù)RAM的寄存器間接尋址有兩種形式:一是采用R0、R1作間址寄存器,這時(shí)R0或R1提供低8位地址,而高8位地址則由P2端口提供;二是采用16位的DPTR作間址寄存器。 3.2.4 寄存器間接尋址寄存器間接尋址例如:設(shè)R0的內(nèi)容為60H,且(60H)=10H,即60H地址單元中的內(nèi)容為10H,
28、則語句MOV A, R0的執(zhí)行過程如圖所示。執(zhí)行后,(A)=10H,即累加器A的內(nèi)容成為10H。01100000ACCR060H10H0001000000010000內(nèi)部RAM圖3.3 MOV A,R0的執(zhí)行示意圖又如:MOVX A, R0 ;(A)(R0),用R0間接尋址的單元中的內(nèi)容替換A的;內(nèi)容。MOVX A, DPTR;(A)(DPTR),用DPTR間接尋址的單元中的內(nèi)容替換;A的內(nèi)容。3.2.5 變址尋址變址尋址這種尋址方式是以數(shù)據(jù)指針DPTR或程序計(jì)數(shù)器PC作為基址寄存器,以累加器A作為偏移量寄存器,將一個(gè)基址寄存器的內(nèi)容與偏移量寄存器的內(nèi)容之和作為操作數(shù)地址。 例如:MOVC A
29、, A+DPTR設(shè)(A)=10H,(DPTR)=1000H,程序存儲(chǔ)器的(1010H)=45H,則上面程序語句的功能是將A的內(nèi)容與DPTR的內(nèi)容相加形成操作數(shù)地址(1010H),把該地址中的數(shù)據(jù)傳送到累加器A。即(A)(A)+(DPTR)。結(jié)果: (A)=45H。 00010000DPHROM00000000DPL00010000ACC00010000+00010000(DPTR)=1010HDPHDPL01000101ACC01000101圖 3.4 MOVC A,A+DPTR的執(zhí)行示意圖 相對(duì)尋址相對(duì)尋址是把指令中給定的地址偏移量rel與程序計(jì)數(shù)器 PC的當(dāng)前值(讀出該雙字節(jié)或三字節(jié)的跳轉(zhuǎn)
30、指令后,PC指向的下條指令的地址)相加,得到真正的程序轉(zhuǎn)移地址。 例如:JC 80H若C=0,則PC值不變,若C=1,則以當(dāng)前PC值為基地址,加上80H得到新的PC值。設(shè)該轉(zhuǎn)移指令存放在1005H單元,取出操作碼后PC指向1006H單元,取出偏移量后PC指向1007H單元,所以計(jì)算偏移量時(shí)PC當(dāng)前地址為1007H,已經(jīng)為轉(zhuǎn)移指令首地址加2,這里的偏移量以補(bǔ)碼給出,所以80H代表著-80H,補(bǔ)碼運(yùn)算后,就形成跳轉(zhuǎn)地址0F87H。其過程如圖所示。 3.2.6 相對(duì)尋址相對(duì)尋址3.2.6 相對(duì)尋址相對(duì)尋址01000000100000000F87H1005PCPCPC10061007ALU1007操作
31、碼偏移量PC圖3.5 JC 80H的執(zhí)行示意圖3.2.7 位尋址位尋址MCS-51單片機(jī)可對(duì)片內(nèi)RAM的兩個(gè)區(qū)域進(jìn)行位尋址:一個(gè)是20H2FH單元的128位,另一個(gè)是特殊功能寄存器的93位。在尋址時(shí),同一個(gè)位地址可以有多種標(biāo)識(shí)方式,讀者可參看后面節(jié)“位操作指令”的相關(guān)內(nèi)容。3.3.1 通用傳送指令通用傳送指令格式:MOV 目的操作數(shù),源操作數(shù)功能:把第二操作數(shù)指定的字節(jié)內(nèi)容傳送到第一操作數(shù)指定的單元中。不影響源操作數(shù)內(nèi)容,不影響別的寄存器和標(biāo)志。 1. 以累加器A為目的操作數(shù)的傳送類指令3.3 數(shù)據(jù)傳送類指令數(shù)據(jù)傳送類指令指令助記符及功能說明如下:例例1 若(50H)=10H,則執(zhí)行指令MOV
32、 A, 50H之后,(A)=10H。例例2 若(R0)=20H,(20H)=39H,則執(zhí)行指令MOV A, R0后,(A)=39H。例例3 若(R5)=55H,則執(zhí)行指令MOV A, R5后,(A)=55H。2. 以Rn為目的操作數(shù)的傳送類指令例例1 若(A)=20H,則執(zhí)行指令MOV R3, A后,(R3)=20H。例例2 若(30H)=01H,則執(zhí)行指令MOV R7, 30H后,(R7)=01H。指令助記符及功能說明如下:例例1 若(30H)=20H,(R0)=30H,則執(zhí)行指令MOV 90H, R0的結(jié)果為(90H)=20H。例例2 若例1中的條件不變,而執(zhí)行指令MOV P1, R0,則
33、(P1)=20H。 3. 以直接地址directX為目的操作數(shù)的傳送類指令指令助記符及功能說明如下:例例1 若(R0)=50H,(50H)=20H,(A)=10H,則執(zhí)行指令“MOV R0, A”后,50H單元的內(nèi)容由原來的20H變?yōu)?0H。4. 以寄存器間接地址Ri為目的操作數(shù)的傳送類指令指令助記符及功能說明如下:5. 16位目標(biāo)地址傳送指令這條指令的功能是:把16位立即數(shù)送入DPTR中。而16位的數(shù)據(jù)指針DPTR由DPH與DPL組成,該指令執(zhí)行后,16位立即數(shù)的高8位送入DPH中,低8位送入DPL中。該指令的執(zhí)行,不影響程序狀態(tài)寄存器PSW。指令助記符及功能說明如下:3.3.2 外部數(shù)據(jù)存
34、儲(chǔ)器外部數(shù)據(jù)存儲(chǔ)器(或或I/O口口)與累加器與累加器A傳送指令傳送指令例例1 設(shè)(P2)=20H,現(xiàn)將A中數(shù)據(jù)存儲(chǔ)到20FFH單元中去??捎靡韵鲁绦?qū)崿F(xiàn):MOV R1, #0FFH ;(R1)0FFHMOVX R1, A ;(20FFH)(A)也可采用下述程序?qū)崿F(xiàn):MOV DPTR, #20FFH ;(DPTR)20FFHMOVX DPTR, A ;(DPTR)(A),即(20FFH)(A)指令助記符與功能說明如下:3.3.2 外部數(shù)據(jù)存儲(chǔ)器外部數(shù)據(jù)存儲(chǔ)器(或或I/O口口)與累加器與累加器A傳送指令傳送指令例例2 將外部數(shù)據(jù)存儲(chǔ)器7FF0H單元中的數(shù)據(jù)取出,存放到外部數(shù)據(jù)存儲(chǔ)器2000H單元中
35、去。MOV DPTR, #7FF0HMOVX A, DPTRMOV DPTR, #2000HMOVX DPTR, A例例1 在外部程序存儲(chǔ)器2000H單元開始存放了數(shù)字09的共陰極數(shù)碼管的16進(jìn)制數(shù)的字形代碼3FH、06H、6FH。要求根據(jù)A中的值(09)來查找該數(shù)字所對(duì)應(yīng)的代碼以便顯示。若用PC作基址寄存器,則需要在MOVC A, A+PC指令前用一加法指令對(duì)地址進(jìn)行調(diào)整:ADD A, #dataMOVC A, A+PC3.3.3 程序存儲(chǔ)器向累加器程序存儲(chǔ)器向累加器A傳送數(shù)據(jù)指令傳送數(shù)據(jù)指令指令助記符與功能說明如下: 1. 字節(jié)交換指令例例1 設(shè)(R1)=30H,(30H)=45H,(A)
36、=7FH,則執(zhí)行指令:XCH A, R1結(jié)果:(A)=45H,而(30H)=7FH,從而實(shí)現(xiàn)了累加器A與內(nèi)部數(shù)據(jù)存儲(chǔ)器RAM中30H單元的數(shù)據(jù)交換。3.3.4 數(shù)據(jù)交換指令數(shù)據(jù)交換指令指令助記符與功能說明如下:2. 半字節(jié)交換指令例例1 設(shè)(30H)=6FH,(R0)=30H,(A)=0F6H,則執(zhí)行指令:XCHD A, Ri結(jié)果:(A)=0FFH,(30H)=66H數(shù)據(jù)交換指令除了影響始終跟蹤A中數(shù)據(jù)奇偶性的P標(biāo)志外,對(duì)PSW中其他標(biāo)志位均無影響。指令助記符與功能說明如下:3. 累加器A中高四位與低四位交換指令SWAP A該指令所執(zhí)行的操作是累加器A中的高4位與低4位的內(nèi)容互換,其結(jié)果仍存放
37、在累加器A中。例例1 設(shè)(A)=0A5H(10100101B),則執(zhí)行指令:SWAP A結(jié)果:(A)=5AH(01011010B)指令SWAP交換了A中高、低半字節(jié)(30和74),結(jié)果不影響標(biāo)志寄存器PSW。3.3.5 堆棧操作指令堆棧操作指令堆棧操作指令只有2條,即:壓入(PUSH)和彈出(POP)。壓入指令:PUSH direct ;SPSP+1,(SP)(direct)彈出指令:POP direct ;(SP)(direct),SPSP-1例1PUSH A ;保護(hù)A中數(shù)據(jù) PUSH PSW ;保護(hù)標(biāo)志寄存器中數(shù)據(jù) ;執(zhí)行服務(wù)程序 POP PSW ;恢復(fù)標(biāo)志寄存器中數(shù)據(jù) POP A ;恢復(fù)
38、A中數(shù)據(jù)例2PUSH A PUSH PSW POP A POP PSW例3 PUSH DPH PUSH DPL POP DPL POP DPH3.4.1 加減運(yùn)算指令加減運(yùn)算指令 1. 加法指令 這類指令所完成的操作是把源操作數(shù)(立即數(shù)、直接地址單元內(nèi)容、間接地址單元內(nèi)容、工作寄存器內(nèi)容)與累加器A的內(nèi)容相加,將結(jié)果保存在累加器A中。 3.4 算術(shù)運(yùn)算類指令算術(shù)運(yùn)算類指令指令助記符與功能說明如下:例例1 執(zhí)行指令:MOV A, #0A9HADD A, #0B8H對(duì)程序狀態(tài)寄存器的影響如圖所示。運(yùn)算結(jié)果:(A)=61H,CY=1,AC=1,OV=1,P=1,(PSW)=0C5H例例2 8位數(shù)加法
39、程序片斷1: MOVA, #23H ADDA, #5AH運(yùn)算結(jié)果:(A)=7DH,CY=0,OV=0,AC=0,P=0,(PSW)=00H。 000000000001111111111111 d7d0d4d3無進(jìn)位AC=0 0 =0,OV=0無進(jìn)位CY=0P=00例例3 8位數(shù)加法程序片斷2:MOVA, #0ABHADDA, #9AH運(yùn)算結(jié)果:(A)=45H,CY=1,OV=1,AC=1,P=1,(PSW)=0C5H。 000001000111000111101111 d7d0d4d3有進(jìn)位AC=1 1 =1,OV=1有進(jìn)位CY=1P=110帶進(jìn)位加法指令與前述加法指令的區(qū)別僅為考慮進(jìn)位位,其
40、他與加法指令相同。2. 帶進(jìn)位加法指令指令助記符與功能說明如下:例例3 利用ADDC指令可以進(jìn)行多字節(jié)的加法運(yùn)算。設(shè)有兩個(gè)16位數(shù)相加,被加數(shù)的高8位放在41H,低8位放在40H,加數(shù)的高8位放在43H,低8位放在42H,和的低8位存放在50H,高8位存放在51H,進(jìn)位位存放在52H??删幊绦蛉缦拢豪? 設(shè)(A)=0AAH,(R0)=55H,C=1,則執(zhí)行指令:ADDC A, R0運(yùn)算結(jié)果:(A)=00000000B,AC=1,CY=1,OV=1。例例2 設(shè)(A)=35H,(40H)=21H,C=0,則執(zhí)行指令:ADDC A, 40H運(yùn)算結(jié)果:(A)=56H,AC=0,CY=0,OV=0。這
41、與執(zhí)行指令“ADD A, 40H”的結(jié)果是一樣的。SHJ: MOV A, 40H;(A)被加數(shù)低8位ADD A, 42H;與加數(shù)低8位相加MOV 50H, A;和的低8位存入50HMOV A, 41H;(A)被加數(shù)高8位ADDC A, 43H;被加數(shù)高8位與加數(shù)高8位以及低位來的進(jìn)位相加MOV 51H, A;和的高8位存入51H單元MOV A, #00H;(A)00HADDC A, #00H;(A)(A) +00H+高8位來的進(jìn)位MOV 52H, A;進(jìn)位位C內(nèi)容存入52H單元3. 帶借位減指令指令助記符與功能說明如下:例例1 設(shè)(40H)=0BAH,(41H)=98H,試編寫40H內(nèi)容減去4
42、1H內(nèi)容后,結(jié)果再存入40H單元的程序。MOVA, 40H;(A)(40H)CLRC;進(jìn)位位C清0SUBBA, 41H;(A)(A)-(41H) -(C)MOV40H, A;(40H)(A)執(zhí)行以上程序后,(40H)=22H,CY=0,OV=0。如果參與運(yùn)算的兩數(shù)為無符號(hào)數(shù),則其溢出與否與OV狀態(tài)無關(guān),而是靠CY是否有借位來判斷,OV僅僅表示帶符號(hào)數(shù)運(yùn)算時(shí)是否溢出。例例2 設(shè)有兩個(gè)16位數(shù)相減,被減數(shù)的高8位放在41H,低8位放在40H,減數(shù)高8位放在43H,低8位放在42H,差的低8位存放在50H,高8位存放在51H,借位位存放在52H。 可編程序如下:SHJIAN:MOV A, 40H ;
43、(A)被減數(shù)低8位CLR C ;C位清0SUBB A, 42H ;減去減數(shù)低8位MOV 50H, A ;差的低8位存入50HMOV A, 41H ;(A)被減數(shù)高8位SUBB A, 43H ;被減數(shù)高8位減去減數(shù)高8位與借位MOV 51H, A ;差的高8位存入51H單元MOV A, #00H ;(A)00HADDC A, #00H ;(A)高8位的借位位MOV 52H, A ;借位位C內(nèi)容存入52H單元1. 乘法指令例例1 設(shè)(A)=67H(103),(B)=0ADH(173),執(zhí)行指令:MUL AB運(yùn)算結(jié)果:乘積為459BH(17819),(A)=9BH,(B)=45H。另外:OV=1,C
44、Y=03.4.2 乘除運(yùn)算指令乘除運(yùn)算指令 MUL AB ;(A)乘積低8位,(B)乘積高8位例例2 設(shè)被乘數(shù)為16位無符號(hào)數(shù),低8位存放在地址為K的單元,高8位存放在地址為K+1的單元。乘數(shù)為8位無符號(hào)數(shù),存放在M單元。編程求出二者乘積,并將乘積的07位存放在R1,815位存放在R2,1623位存放在R3中。分析:16位無符號(hào)數(shù)與8位無符號(hào)數(shù)相乘的步驟示意如下:程序編制如下:MOV R0, #K ;設(shè)置被乘數(shù)地址指針MOV A, R0 ;被乘數(shù)送A中MOV B, M ;乘數(shù)送B中MUL AB ;(K)(M)MOV R1, A ;乘積的07位存入R1MOV R2, B ;暫存積的815位INC
45、 R0 ;指向被乘數(shù)高8位地址MOV A, R0 ;取被乘數(shù)高8位MOV B, M ;乘數(shù)送B中MUL AB ;(K+1)(M)ADD A, R2 ;求得乘積的815位MOV R2, A ;乘積的815位存入R2MOV A, BADDC A, #00H ;求得乘積的1623位MOV R3, A ;乘積的1623位存入R3 K+1 K M R1 R2 A B + R1 R2 R3 2. 除法指令例例1 設(shè)(A)=9AH,(B)=23H,執(zhí)行指令:DIV AB則(A)=04H,(B)=0EH,OV=00H,CY=00H3.4.2 乘除運(yùn)算指令乘除運(yùn)算指令 DIV AB ;(A)商,(B)余數(shù)3.4
46、.3 增增1減減1指令指令1. 增1指令I(lǐng)NC A ;(A)(A)+1INC direct ;(direct)(direct)+1INC Ri ;(Ri)(Ri)+1INC Rn ;(Rn)(Rn)+1INC DPTR ;(DPTR)(DPTR)+1例例1 設(shè)(A)=40H,(41H)=29H,則執(zhí)行下列指令:INC A;(A)40H+1HINC 41H;(41H)29H+1H結(jié)果:(A)=41H,(41H)=2AH例例2 設(shè)(R0)=56H,片內(nèi)RAM單元(56H)=0FFH,(57H)=50H,則執(zhí)行下列指令:INC R0;(56H)00HINC R0;(R0)57HINC R0;(57H
47、)51H結(jié)果:(56H)=00H,(R0)=57H,(57H)=51H例例3 執(zhí)行下述指令序列:MOV DPTR,#2FFEH ;(DPTR)2FFEHINC DPTR;(DPTR)2FFFHINC DPTR;(DPTR)3000HINC DPTR;(DPTR)3001H則(DPTR)=3001H2. 減1指令DEC A;(A)(A)-1DEC direct;(direct)(direct)-1DEC Ri;(Ri)(Ri)-1DEC Rn;(Rn)(Rn)-1例例1 設(shè)(R0)=4FH,片內(nèi)RAM單元(4FH)=40H,(4EH)=00H,執(zhí)行指令:DEC R0 ;(4FH)3FHDEC R
48、0 ;(R0)4EHDEC R0 ;(4EH)0FFH結(jié)果:(R0)=4EH,(4EH)=0FFH,(4FH)=3FH3.4.4 二二/十進(jìn)制調(diào)整指令十進(jìn)制調(diào)整指令 DA A該指令的功能是對(duì)累加器A中的“二/十”進(jìn)制(BCD碼)加法結(jié)果進(jìn)行調(diào)整。例例1 執(zhí)行下面的指令:MOVA, #86HADDA, #47H結(jié)果:(A)=0CDH,CY=0,AC=0所得結(jié)果并不是BCD碼,若接著執(zhí)行以下指令:DA A則結(jié)果:(A)=33H,CY=1,AC=11. 累加器A清0指令格式:CLR A功能:將00H送入累加器A中。3.5 邏輯運(yùn)算指令邏輯運(yùn)算指令3.5.1 單操作數(shù)指令單操作數(shù)指令2. 累加器A取反
49、指令格式:CPL A功能:將累加器A中內(nèi)容取反(將A中內(nèi)容按位取反,即邏輯非運(yùn)算)后再送回累加器A中。例例1 設(shè)(A)=98H,執(zhí)行指令CLR A ;(A)0CPL A ;(A)0FFH結(jié)果:(A)=0FFH3. 累加器A內(nèi)容循環(huán)左移一位指令格式:RL A功能:將累加器A中的內(nèi)容循環(huán)左移一位。即A7A0例例1 設(shè)(A)=10001000,則執(zhí)行指令“RL A”后,結(jié)果:(A)=0001000110000001A0A1A2A3A4A5A6A7執(zhí)行RL A指令前10000001執(zhí)行RL A指令后A0A1A2A3A4A5A6A74. 累加器A內(nèi)容帶進(jìn)位位CY循環(huán)左移一位指令格式:RLC A功能:將累
50、加器A中的內(nèi)容與進(jìn)位標(biāo)志位CY一起循環(huán)左移一位。即:A7A0CY例例1 設(shè)(A)=01010101,(CY)=1。則執(zhí)行指令“RLC A”后,結(jié)果:(A)=10101011,(CY)=0。執(zhí)行RLC A指令前執(zhí)行RLC A指令后10100101A0A1A2A3A4A5A6A7CY1101111000A0A1A2A3A4A5A6A7CY5. 累加器A內(nèi)容循環(huán)右移一位指令格式:RR A功能:將累加器A中的內(nèi)容循環(huán)右移一位。即:A7A0例例1 設(shè)(A)=00010001,則執(zhí)行指令“RR A”后,結(jié)果:(A)=1000100010000001A0A1A2A3A4A5A6A7執(zhí)行RR A指令前1000
51、0001A0A1A2A3A4A5A6A7執(zhí)行RR A指令后6. 累加器A內(nèi)容帶進(jìn)位位CY循環(huán)右移一位指令格式:RRC A功能:將累加器A中的內(nèi)容與進(jìn)位標(biāo)志位CY一起循環(huán)右移一位。即:A7A0CY例例1 設(shè)(A)=10101011,(CY)=0。則執(zhí)行指令“RRC A”后,結(jié)果:(A)=01010101,(CY)=1。執(zhí)行RRC A指令前執(zhí)行RRC A指令后10100101110111100A0A1A2A3A4A5A6A7CY0A0A1A2A3A4A5A6A7CY3.5.2 雙操作數(shù)指令雙操作數(shù)指令1. 邏輯與指令邏輯與的規(guī)則定義為:(其中表示邏輯與)00=001=10=011=1例例1 設(shè)(A
52、)=0C3H,(R3)=0ADH,執(zhí)行指令“ANL A, R3”。結(jié)果:(A)=81H(10000001B)。指令執(zhí)行過程如下:100001110C3H ()0ADH11 000 111()0 10 0 01 0 081HBB(B )2. 邏輯或指令邏輯或的規(guī)則定義為:(其中表示邏輯或)00=000=10=111=1例例1 設(shè)(A)=0C3H,(R3)=0ADH,執(zhí)行指令“ORL A, R3”。結(jié)果:(A)=0EFH(11101111B)。指令執(zhí)行過程如下:100001110C3H ()0ADH11 000 111()1 10 1 11 1 10EFHBB(B )3. 邏輯異或指令邏輯異或的規(guī)
53、則定義為(其中 表示邏輯異或):0 0=1 1=01 0=0 1=1例例1 設(shè)(A)=0C3H,(R3)=0ADH,執(zhí)行指令“XRL A, R3”。結(jié)果:(A)=6EH(01101110B)。指令執(zhí)行過程如下:100001110C3H ()0ADH11 000 111()1 00 1 10 1 16EHBB(B )例2 試把分別保存在30H、31H單元中用ASCII碼表示的兩位數(shù),轉(zhuǎn)換成兩位BCD碼,并以壓縮BCD碼形式存入30H單元中。程序如下:ANL 30H, #0FH;30H單元的ASCII碼轉(zhuǎn)換成BCD碼MOV A, 31H;取31H單元的ASCII碼ANL A, #0FH;31H單元
54、的ASCII碼變成BCD碼RL ARL ARL ARL AORL 30H, A;結(jié)果存入30H單元例例1 要將20H位的內(nèi)容傳送給23H位,不能直接用“MOV 20H, 23H”,因?yàn)樵撝噶顖?zhí)行的實(shí)際是字節(jié)傳送,若要將20H位的內(nèi)容傳送給23H位,可用下述程序?qū)崿F(xiàn):MOV C, 20H ;(C)(20H)MOV 23H, C ;(23H)(C)3.6 位操作類指令位操作類指令3.6.1 位數(shù)據(jù)傳送指令位數(shù)據(jù)傳送指令指令助記符與功能說明如下:目的操作數(shù) 源操作數(shù) 功能說明MOV C, bit;(C)(bit)MOV bit, C;(C)(bit)指令格式如下:CLR C;(C)(0)CLR bi
55、t;( bit)(0)以上指令可使直接尋址位(bit)或位累加器C清0,不影響其他標(biāo)志。例例1 片內(nèi)RAM單元26H的內(nèi)容為0FFH,執(zhí)行指令:CLR 32H結(jié)果:(26H)=0FBH(11111011B),其中,32H為26H單元第二位的位地址。3.6.2 位狀態(tài)控制指令位狀態(tài)控制指令 1. 位清0指令指令格式如下:CPL C ;(C)(/C)CPL bit ;(bit)(/bit)以上指令把位累加器C或者直接尋址位(bit)內(nèi)容取反,不影響其他標(biāo)志位。例例1 執(zhí)行下面的指令序列:MOV P1,#2FH;(P1)(2FH即00101111B)位求反位求反結(jié)果:(P1)=2AH(0010101
56、0B)。2. 位求反指令指令格式如下:SETB C;(C)1SETB bit;(bit)1以上指令把進(jìn)位標(biāo)志C或者任何可直接尋址位(bit)置1,不影響其他標(biāo)志位。例例1 假設(shè)進(jìn)位標(biāo)志C內(nèi)容為0,輸出口P1原來的內(nèi)容為0FH(00001111B),則執(zhí)行下面指令:SETB C結(jié)果:(C)=1,(P1)=8FH(10001111B)。 3. 位置1指令例例1 當(dāng)位地址(2AH)=1,(32H)=1,同時(shí)累加器中(ACC.7)=0時(shí),進(jìn)位位C=1,否則C清0,可編程序如下:MOVC, 2AH ;(C)(2AH)ANLC, 32H ;(C)(C)(32H)ANLC, /ACC.7 ;(C)(C)(/
57、ACC.7)3.6.3 位邏輯操作指令位邏輯操作指令 1. 位與指令指令助記符與功能說明如下:目的操作數(shù) 源操作數(shù) 功能說明ANL C, bit ;(C)(C)(bit)ANL C, /bit ;(C)(C)(/bit)指令助記符與功能說明如下:目的操作數(shù) 源操作數(shù) 功能說明ORL C, bit ;(C)(C)(bit)ORL C, /bit ;(C)(C)(/bit)位或指令的功能是將直接尋址位的內(nèi)容或直接尋址位內(nèi)容取反后(不改變?cè)瓉砦坏膬?nèi)容)和位累加器C的內(nèi)容相或,結(jié)果保存在C中。例例1 寫出位地址(2AH)=1和(32H)=1、累加器(ACC.7)=0相或的程序:MOVC, 2AH ;(
58、C)(2AH)ORLC, 32H ;(C)(C)(32H)ORLC, ACC.7 ;(C)(C)(ACC.7)結(jié)果:(C)=1。2. 位或指令圖為判C轉(zhuǎn)移指令的執(zhí)行過程。3.6.4 位條件轉(zhuǎn)移指令位條件轉(zhuǎn)移指令1. 判C轉(zhuǎn)移指令JCrel ;若(C)=1,則(PC)(PC)+2+rel;若(C)=0,則(PC)(PC)+2JNCrel ;若(C)=0,則(PC)(PC)+rel;若(C)=1,則(PC)(PC)+2(PC)(PC)+2C=1?NY(PC)(PC)+rel(PC)(PC)+2C=0?NY(PC)(PC)+rel(a) JC rel (b) JNC rel圖3.7 判C轉(zhuǎn)移指令的執(zhí)
59、行過程JBbit, rel;若(bit)=1,則(PC)(PC)+3+rel ;若(bit)=0,則(PC)(PC)+3JNBbit, rel;若(bit)=0,則(PC)(PC)+3+rel ;若(bit)=1,則(PC)(PC)+3JBCbit, rel;若(bit)=1,則(PC)(PC)+3+rel,而且(bit)清0 ;若(bit)=0,則(PC)(PC)+32. 判直接尋址位轉(zhuǎn)移指令判直接尋址位轉(zhuǎn)移指令的執(zhí)行過程如圖所示。(PC)(PC)+3bit=1?NY(PC)(PC)+rel(PC)(PC)+3bit=0?NY(PC)(PC)+rel(PC)(PC)+3bit=1?NY(PC
60、)(PC)+relbit=0(a) JB bit, rel (b) JNB bit, rel (c) JBC bit, rel例例1 假設(shè)前面的程序段一樣,則分別執(zhí)行下面三段程序。程序1:SETB32H;(32H)1JB32H, K1;(32H)=1轉(zhuǎn)K1處執(zhí)行K1:程序2:CLR32H;(32H)0JNB32H, K1;(32H)=0轉(zhuǎn)K1處執(zhí)行K1:程序3:SETB32H;(32H)1JBC32H, K1;(32H)=1轉(zhuǎn)K1處執(zhí)行K1:1. 長轉(zhuǎn)移指令 指令格式:LJMP addr16 ;(PC)addr0153.7 控制轉(zhuǎn)移類指令控制轉(zhuǎn)移類指令3.7.1 無條件轉(zhuǎn)移指令無條件轉(zhuǎn)移指令例
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度特色小吃街餐飲店鋪?zhàn)赓U合同
- 二零二五年度特種電工安全作業(yè)協(xié)議書:核電站電工作業(yè)安全合同
- 二零二五年度股權(quán)質(zhì)押合同工商登記及企業(yè)財(cái)務(wù)風(fēng)險(xiǎn)管理服務(wù)協(xié)議
- 二零二五年度醫(yī)療健康領(lǐng)域?qū)I(yè)技術(shù)人員雇傭合同
- 社交技能訓(xùn)練與孩子自信心的提升
- 二零二五年度畫室品牌形象與使用權(quán)轉(zhuǎn)讓合同
- 2024-2025學(xué)年高中生物專題四酶的研究與應(yīng)用課題3酵母細(xì)胞的固定化作業(yè)含解析新人教版選修1
- 二零二五年度農(nóng)業(yè)機(jī)械設(shè)備銷售與租賃合同范本
- 二零二五年度住宅小區(qū)智能化改造物業(yè)管理委托協(xié)議
- 2025年度輪胎行業(yè)供應(yīng)鏈金融服務(wù)合同
- 江蘇省鹽城市鹿鳴路初級(jí)中學(xué)2024-2025學(xué)年八年級(jí)上學(xué)期期末考試語文試題(含答案)
- 新蘇教版一年級(jí)數(shù)學(xué)下冊(cè)第六單元《簡單的數(shù)量關(guān)系(一)》教案(共2課時(shí))
- 浙江省寧波市九校2024-2025學(xué)年高一上學(xué)期期末聯(lián)考試題 數(shù)學(xué) 含答案
- GA/T 2146-2024法庭科學(xué)涉火案件物證檢驗(yàn)移動(dòng)實(shí)驗(yàn)室建設(shè)通用要求
- 北京市石景山區(qū)2024-2025學(xué)年九年級(jí)上學(xué)期期末考試數(shù)學(xué)試卷(含答案)
- 社會(huì)兒童福利院項(xiàng)目可行性研究報(bào)告
- 腦卒中后吞咽障礙患者進(jìn)食護(hù)理-2023中華護(hù)理學(xué)會(huì)團(tuán)體標(biāo)準(zhǔn)
- 系統(tǒng)解剖學(xué)考試重點(diǎn)筆記
- 云南省地圖含市縣地圖矢量分層地圖行政區(qū)劃市縣概況ppt模板
- 暖通空調(diào)基礎(chǔ)知識(shí)及識(shí)圖課件
- 防滲墻工程施工用表及填寫要求講義
評(píng)論
0/150
提交評(píng)論