arm 學(xué)習(xí)筆記--C程序基礎(chǔ)
數(shù)據(jù)類型
arm 基本數(shù)據(jù)類型包括 整數(shù)型和 浮點(diǎn)數(shù)類型。
整數(shù)類型:
Char 長(zhǎng)度為8位的字節(jié)數(shù)據(jù);
Short 長(zhǎng)度為16位的半字?jǐn)?shù)據(jù);
Int 長(zhǎng)度為32位的字?jǐn)?shù)據(jù);
Long 長(zhǎng)度為32位的字?jǐn)?shù)據(jù);
Long Long 長(zhǎng)度為64位的雙字?jǐn)?shù)據(jù);
浮點(diǎn)型:
Float 長(zhǎng)度為32位的浮點(diǎn)數(shù);
Double 長(zhǎng)度為64位的浮點(diǎn)數(shù);
c語(yǔ)言操作中,如果遇到無(wú)符號(hào)數(shù)和有符號(hào)數(shù)之間的操作,編譯器會(huì)自動(dòng)轉(zhuǎn)化為無(wú)符號(hào)數(shù)來(lái)進(jìn)行處理,符號(hào)位作為數(shù)值位處理。
字符由單引號(hào)及其所引起來(lái)的字符表示。
字符串由雙引號(hào)及其所引起來(lái)的字符表示。
結(jié)構(gòu)體中,為了地址邊界對(duì)齊,避免被編譯器填充無(wú)意義的填充位,浪費(fèi)了存儲(chǔ)空間,應(yīng)該把位數(shù)小的數(shù)據(jù)放在結(jié)構(gòu)的前面。
eg.
struct arm
{
char a;
char c;
short d;
int b;
}
通過(guò)#define和#undef 可以實(shí)現(xiàn)宏定義和刪除宏
宏定義可以設(shè)置帶參數(shù)形式:
eg.
#define mul(a,b)((a)*(b)) // 調(diào)用mul(1,2)時(shí)即為1*2
#define DELAY(a) while(--a)
int a=XXXXXX; DELAY(a); 就可以實(shí)現(xiàn)一個(gè)基本的延時(shí)函數(shù)
通過(guò)#error 可以輸出錯(cuò)誤信息
eg.
if(0){
#error "Something Is Wrong .. ";
}
條件編譯指令:
#if(判斷語(yǔ)句)
...語(yǔ)句段...
#elif(判斷語(yǔ)句)
...語(yǔ)句段...
#else
...語(yǔ)句段...
#endif
若#if 指令后常量表達(dá)式為真,則編譯#if到#else之間的程序段,否則編譯#else到#endif之間的程序段。
在程序調(diào)試中,可以用#if指令 臨時(shí)注釋掉一段代碼。
#if 0 ... #endif
1.__irq
用于表示一個(gè)函數(shù)是否為中斷函數(shù)。(eg: void __irq IRQ_Eint0(void){})
2.__swi
這個(gè)關(guān)鍵詞用來(lái)定義軟件中斷,這個(gè)函數(shù)可以有參數(shù)和返回值。
eg:
__swi(0) int add_two(int,int);
__swi(1) int multiply_two(int,int);
在程序中調(diào)用這些函數(shù)就會(huì)產(chǎn)生一個(gè)軟件中斷,進(jìn)而調(diào)用軟件中斷處理函數(shù)。
3.__asm
這個(gè)關(guān)鍵詞告訴編譯器后面的代碼為匯編代碼。用于實(shí)現(xiàn)C語(yǔ)言和匯編語(yǔ)言的混合編程。
混合編程有兩種方法一種為 內(nèi)聯(lián)匯編 一種為 嵌入式匯編。
內(nèi)聯(lián)匯編指在c函數(shù)中插入?yún)R編語(yǔ)句。
eg:
int add(int i ,int j)
{
int res;
__asm
{
ADD res,i,j;
}
return res;
}
嵌入式匯編在形式上表現(xiàn)為獨(dú)立定義的函數(shù)。
eg:
__asm void add(int i)
{
ADD r0,r0,#1;
}
volatile變量 用于防止編譯器訪問(wèn)上次訪問(wèn)的緩存值。編譯器有一種技術(shù)叫數(shù)據(jù)流分析,分析程序的變量在哪賦值,在哪使用,在哪失效。當(dāng)察覺(jué)到你的代碼沒(méi)有修改變量的值,在你訪問(wèn)變量時(shí)就提供上次訪問(wèn)的緩存值。這樣雖然可以提高程序的效率,但在有中斷函數(shù)的程序中就會(huì)帶來(lái)麻煩。中斷可能會(huì)修改該變量的值,而編譯器無(wú)法更新緩存。用 volatile變量可以禁止編譯器使用這種優(yōu)化。
eg: volatile char AAA;
除法運(yùn)算中如果除數(shù)是2的n次方,編譯器會(huì)用移位操作來(lái)完成除法運(yùn)算,無(wú)符號(hào)數(shù)的除法運(yùn)算會(huì)比有符號(hào)數(shù)效率高。
c語(yǔ)言中使用if選擇語(yǔ)句時(shí),在if判斷語(yǔ)句中使用關(guān)系運(yùn)算符(<,=,>等)和邏輯運(yùn)算符(&&,!等),可以使其執(zhí)行體中使用條件執(zhí)行指令,使用條件執(zhí)行指令可以減少跳轉(zhuǎn)指令的數(shù)量。 if 和 else 的執(zhí)行體,應(yīng)盡可能的簡(jiǎn)單。判斷關(guān)系式 構(gòu)成一個(gè)組。
eg.
int g(int a ,int b,int c,int d)
{
if(a>0&&b>0&&c<0&&d<0 )
return a+b+c+d;
}
中斷程序基本原則:
1.避免在中斷程序中做浮點(diǎn)運(yùn)算,中斷程序應(yīng)該短而有效。
2.中斷程序不能有返回值,所以中斷程序都定義返回類型為void。
3.中斷程序不能傳遞參數(shù),所以中斷程序的參數(shù)列表為void。