資料介紹
14.4 布爾表達(dá)式
14.4.1 范圍檢測(cè)
通常,布爾表達(dá)式被用來(lái)檢測(cè)某個(gè)數(shù)值是否在特定的范圍內(nèi)。例如,在圖形窗口處理程序中,常使用布爾表達(dá)式判斷屏幕中一個(gè)點(diǎn)是否在當(dāng)前活動(dòng)窗口范圍內(nèi)。
下面的程序使用結(jié)構(gòu)體定義點(diǎn)坐標(biāo)并計(jì)算坐標(biāo)的當(dāng)前位置。
bool PointInRect1(Point p, Rectangle *r)
{ return (p.x 》= r-》xmin && p.x 《 r-》xmax &&
p.y 》= r-》ymin && p.y 《 r-》ymax);
}
上面的功能函數(shù),被編譯為下面的指令序列。
PointInRect1
LDR a4,[a3,#0]
CMP a1,a4
BLT |L000034.J5.PointInRect1|
LDR a4,[a3,#4]
CMP a4,a1
BLE |L000034.J5.PointInRect1|
LDR a1,[a3,#8]
CMP a2,a1
BLT |L000034.J5.PointInRect1|
LDR a1,[a3,#&c]!
CMP a2,a1
MOVLT a1,#1
MOVLT pc,lr
|L000034.J5.PointInRect1|
MOV a1,#0
MOV pc,lr
但上面的代碼并不是最精簡(jiǎn)的。編譯器對(duì)(x 》= min && x 《 max)形式的布爾表達(dá)式的處理過(guò)程比較復(fù)雜。它將以(unsigned)(x-min) 《 (max-min)形式實(shí)現(xiàn)布爾操作。所有對(duì)于上面范圍判斷的代碼,建議將函數(shù)寫(xiě)成如下形式。
bool PointInRect2(Point p, Rectangle *r)
{ return ((unsigned) (p.x - r-》xmin) 《 r-》xmax &&
(unsigned) (p.y - r-》ymin) 《 r-》ymax);
}
這樣編譯出的匯編指令序列如下所示。
PointInRect2
LDR a4,[a3,#0]
SUB a1,a1,a4
LDR a4,[a3,#4]
CMP a1,a4
LDRCC a1,[a3,#8]
SUBCC a1,a2,a1
LDRCC a2,[a3,#&c]!
CMPCC a1,a2
MOVCS a1,#0
MOVCC a1,#1
MOV pc,lr
14.4.2 和零的比較操作
比較指令(CMP)將設(shè)置程序狀態(tài)字的條件標(biāo)志位。另外,基本的算術(shù)指令也可以設(shè)置條件標(biāo)志位,如使用指令MOVS、ADDS等。如果程序中的算術(shù)指令的執(zhí)行目的是為了將計(jì)算結(jié)果和零比較,那么就可以直接使用帶標(biāo)志擴(kuò)展的基本算術(shù)指令。如下面的兩條語(yǔ)句:
ADD R0, R0, R1
CMP R0, #0
可以合并為一條帶符號(hào)擴(kuò)展的加法指令:
ADDS R0, R0, R1
事實(shí)上,C語(yǔ)言中的和零相關(guān)的關(guān)系操作都可以利用狀態(tài)標(biāo)志寄存器的N位和Z位。如:x 《 0, x 》= 0, x = 0, x != 0,和無(wú)符號(hào)操作x = 0, x != 0 (or x 》 0)。
對(duì)于每一條C語(yǔ)言中的關(guān)系操作,匯編器都將產(chǎn)生一條比較指令。如果關(guān)系操作和零相關(guān),則可以將產(chǎn)生的比較指令移除。
下面是C語(yǔ)言中的關(guān)系操作被編譯的例子。
C源文件如下所示。
int g(int x, int y)
{
if ((x + y) 《 0)
return 1;
else
return 0;
}
編譯后的結(jié)果如下。
g
ADDS a1,a1,a2
MOVPL a1,#0
MOVMI a1,#1
MOV pc,lr
所以,在使用C語(yǔ)言編程時(shí),關(guān)系操作最好轉(zhuǎn)換成和零相關(guān)的,這樣既可以減少代碼密度,也可以提高程序的執(zhí)行效率。
C語(yǔ)言中,沒(méi)有和程序狀態(tài)寄存器的C位和V位直接相關(guān)的指令,所以要在程序中檢測(cè)這些標(biāo)志,只能使用內(nèi)嵌匯編。但C編譯器支持無(wú)符號(hào)溢出操作,下面的例子顯示了在有溢出操作時(shí),編譯器對(duì)程序的處理。
C源代碼如下所示。
int sum(int x, int y)
{
int res;
res = x + y;
if ((unsigned) res 《 (unsigned) x) /* 判斷進(jìn)位標(biāo)志是否進(jìn)位 */
res++;
return res;
}
編譯的匯編文件如下所示。
sum
ADDS a2,a1,a2
ADC a2,a2,#0
MOV a1,a2
MOV pc,lr
?
14.4.1 范圍檢測(cè)
通常,布爾表達(dá)式被用來(lái)檢測(cè)某個(gè)數(shù)值是否在特定的范圍內(nèi)。例如,在圖形窗口處理程序中,常使用布爾表達(dá)式判斷屏幕中一個(gè)點(diǎn)是否在當(dāng)前活動(dòng)窗口范圍內(nèi)。
下面的程序使用結(jié)構(gòu)體定義點(diǎn)坐標(biāo)并計(jì)算坐標(biāo)的當(dāng)前位置。
bool PointInRect1(Point p, Rectangle *r)
{ return (p.x 》= r-》xmin && p.x 《 r-》xmax &&
p.y 》= r-》ymin && p.y 《 r-》ymax);
}
上面的功能函數(shù),被編譯為下面的指令序列。
PointInRect1
LDR a4,[a3,#0]
CMP a1,a4
BLT |L000034.J5.PointInRect1|
LDR a4,[a3,#4]
CMP a4,a1
BLE |L000034.J5.PointInRect1|
LDR a1,[a3,#8]
CMP a2,a1
BLT |L000034.J5.PointInRect1|
LDR a1,[a3,#&c]!
CMP a2,a1
MOVLT a1,#1
MOVLT pc,lr
|L000034.J5.PointInRect1|
MOV a1,#0
MOV pc,lr
但上面的代碼并不是最精簡(jiǎn)的。編譯器對(duì)(x 》= min && x 《 max)形式的布爾表達(dá)式的處理過(guò)程比較復(fù)雜。它將以(unsigned)(x-min) 《 (max-min)形式實(shí)現(xiàn)布爾操作。所有對(duì)于上面范圍判斷的代碼,建議將函數(shù)寫(xiě)成如下形式。
bool PointInRect2(Point p, Rectangle *r)
{ return ((unsigned) (p.x - r-》xmin) 《 r-》xmax &&
(unsigned) (p.y - r-》ymin) 《 r-》ymax);
}
這樣編譯出的匯編指令序列如下所示。
PointInRect2
LDR a4,[a3,#0]
SUB a1,a1,a4
LDR a4,[a3,#4]
CMP a1,a4
LDRCC a1,[a3,#8]
SUBCC a1,a2,a1
LDRCC a2,[a3,#&c]!
CMPCC a1,a2
MOVCS a1,#0
MOVCC a1,#1
MOV pc,lr
14.4.2 和零的比較操作
比較指令(CMP)將設(shè)置程序狀態(tài)字的條件標(biāo)志位。另外,基本的算術(shù)指令也可以設(shè)置條件標(biāo)志位,如使用指令MOVS、ADDS等。如果程序中的算術(shù)指令的執(zhí)行目的是為了將計(jì)算結(jié)果和零比較,那么就可以直接使用帶標(biāo)志擴(kuò)展的基本算術(shù)指令。如下面的兩條語(yǔ)句:
ADD R0, R0, R1
CMP R0, #0
可以合并為一條帶符號(hào)擴(kuò)展的加法指令:
ADDS R0, R0, R1
事實(shí)上,C語(yǔ)言中的和零相關(guān)的關(guān)系操作都可以利用狀態(tài)標(biāo)志寄存器的N位和Z位。如:x 《 0, x 》= 0, x = 0, x != 0,和無(wú)符號(hào)操作x = 0, x != 0 (or x 》 0)。
對(duì)于每一條C語(yǔ)言中的關(guān)系操作,匯編器都將產(chǎn)生一條比較指令。如果關(guān)系操作和零相關(guān),則可以將產(chǎn)生的比較指令移除。
下面是C語(yǔ)言中的關(guān)系操作被編譯的例子。
C源文件如下所示。
int g(int x, int y)
{
if ((x + y) 《 0)
return 1;
else
return 0;
}
編譯后的結(jié)果如下。
g
ADDS a1,a1,a2
MOVPL a1,#0
MOVMI a1,#1
MOV pc,lr
所以,在使用C語(yǔ)言編程時(shí),關(guān)系操作最好轉(zhuǎn)換成和零相關(guān)的,這樣既可以減少代碼密度,也可以提高程序的執(zhí)行效率。
C語(yǔ)言中,沒(méi)有和程序狀態(tài)寄存器的C位和V位直接相關(guān)的指令,所以要在程序中檢測(cè)這些標(biāo)志,只能使用內(nèi)嵌匯編。但C編譯器支持無(wú)符號(hào)溢出操作,下面的例子顯示了在有溢出操作時(shí),編譯器對(duì)程序的處理。
C源代碼如下所示。
int sum(int x, int y)
{
int res;
res = x + y;
if ((unsigned) res 《 (unsigned) x) /* 判斷進(jìn)位標(biāo)志是否進(jìn)位 */
res++;
return res;
}
編譯的匯編文件如下所示。
sum
ADDS a2,a1,a2
ADC a2,a2,#0
MOV a1,a2
MOV pc,lr
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- Oracle中常用的函數(shù)與表達(dá)式講解
- 基于運(yùn)算符信息的數(shù)學(xué)表達(dá)式檢索技術(shù) 2次下載
- Python正則表達(dá)式指南 10次下載
- LabVIEW之表達(dá)式節(jié)點(diǎn)、公式節(jié)點(diǎn)和公式VI 23次下載
- Python正則表達(dá)式的學(xué)習(xí)指南 0次下載
- C語(yǔ)言指針的表達(dá)式實(shí)例程序說(shuō)明 4次下載
- C++程序設(shè)計(jì)教程之數(shù)據(jù)類(lèi)型與表達(dá)式的詳細(xì)資料說(shuō)明 0次下載
- C語(yǔ)言實(shí)用教程之數(shù)據(jù)類(lèi)型運(yùn)算符和表達(dá)式的詳細(xì)資料說(shuō)明 10次下載
- C++入門(mén)教程之數(shù)據(jù)類(lèi)型、運(yùn)算符和表達(dá)式的詳細(xì)資料說(shuō)明 2次下載
- Python正則表達(dá)式教程之標(biāo)準(zhǔn)庫(kù)的完整介紹及使用示例說(shuō)明 3次下載
- C語(yǔ)言教程之C語(yǔ)言中級(jí)培訓(xùn)教程—何謂表達(dá)式 0次下載
- 如何編寫(xiě)C語(yǔ)言代碼中的乘法正確表達(dá)式詳細(xì)概述 4次下載
- C語(yǔ)言程序設(shè)計(jì)--運(yùn)算符與表達(dá)式
- 防范表達(dá)式的失控
- 基因表達(dá)式編程的2種解碼方法
- GVIM正則表達(dá)式介紹和使用示例 1357次閱讀
- 什么是正則表達(dá)式?正則表達(dá)式如何工作?哪些語(yǔ)法規(guī)則適用正則表達(dá)式? 3819次閱讀
- Java Lambda表達(dá)式的新特性 2618次閱讀
- OpenHarmony中使用正則表達(dá)式 1506次閱讀
- shell腳本基礎(chǔ):正則表達(dá)式grep 1285次閱讀
- Python中的Lambda表達(dá)式 851次閱讀
- 位邏輯運(yùn)算符與表達(dá)式 1284次閱讀
- 邏輯運(yùn)算符與表達(dá)式 2205次閱讀
- C語(yǔ)言的表達(dá)式 1405次閱讀
- 表達(dá)式與邏輯門(mén)之間的關(guān)系 1662次閱讀
- 運(yùn)算符/表達(dá)式規(guī)則 1032次閱讀
- RTL表達(dá)式和運(yùn)算符 1793次閱讀
- C語(yǔ)言如何使用正則表達(dá)式 4970次閱讀
- 教你如何輕松搞定Linux正則表達(dá)式 3645次閱讀
- 快速入門(mén)IPv6和正則表達(dá)式 9051次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1490次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 92次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識(shí)別和講解說(shuō)明
- 4.28 MB | 18次下載 | 4 積分
- 5開(kāi)關(guān)電源原理及各功能電路詳解
- 0.38 MB | 10次下載 | 免費(fèi)
- 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
- 7藍(lán)牙設(shè)備在嵌入式領(lǐng)域的廣泛應(yīng)用
- 0.63 MB | 3次下載 | 免費(fèi)
- 89天練會(huì)電子電路識(shí)圖
- 5.91 MB | 3次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專(zhuān)業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537791次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評(píng)論