Ⅰ c51語言頭文件包括的內容有8051單片機
3章C51編程語言基礎
【內容概要】本章介紹有關C51語言編程的基礎知識,對C51語言與8051匯編語言編程進行比較,了解C51語言與標准C語言的差別,並對C51語言的數據類型與存儲類型,C51語言的基本運算,分支與循環結構,數組、指針、函數等也做以介紹。
隨著單片機應用系統的日趨復雜,對程序的可讀性、升級與維護以及模塊化的要求越來越高,對軟體編程的要求也越來越高,這就要求編程人員在短時間內編寫出執行效率高、運行可靠的程序代碼。同時,也要方便多個編程人員來進行協同開發。
C51語言是目前的8051單片機應用開發中,普遍使用的程序設計語言。C51語言能直接對8051單片機硬體進行操作,它既有高級語言的特點,又有匯編語言的特點,因此在8051單片機程序設計中,C51語言得到非常廣泛的使用。
3.1C51編程語言簡介
C51語言是在標准C語言的基礎上針對8051單片機的硬體特點進行了擴展,並向8051單片機上移植,經過多年努力,C51語言已成為公認的高效、簡潔的8051單片機的實用高級編程語言。與8051匯編語言相比,C51語言在功能上、結構性、可讀性、可維護性上有明顯優勢,且易學易用。
3.1.1C51語言與8051匯編語言的比較
與8051單片機匯編語言相比, C51語言具有如下優點。
(1)可讀性好。C51語言程序比匯編語言程序的可讀性好,編程效率高,程序便於修改、維護以及升級。
(2)模塊化開發與資源共享。用C51語言開發的程序模塊可以不經修改,直接被其他工程所用,使得開發者能夠很好地利用已有的大量標准C程序資源與豐富的庫函數,從而減少重復勞動,同時也有利於多個程序設計者協同開發。
(3)可移植性好。為某種型號單片機開發的C語言程序,只需將與硬體相關的頭文件和編譯鏈接的參數進行適當修改,就可方便地移植到其他型號的單片機上。例如,為8051單片機編寫的程序通過改寫頭文件以及少量的程序行,就可方便地移植到PIC單片機上。
(4)生成的代碼效率高。當前較好的C51語言編譯系統編譯出來的代碼,效率只比直接使用匯編語言低20%左右,如果使用優化編譯選項,最高效率可達到90%。
3.1.2C51語言與標准C語言的比較
C51語言與標准C語言有許多相同之處,但也有其自身的一些特點。不同的嵌入式C語言編譯系統之所以與標准C語言有不同的地方,主要是由於它們所針對的硬體系統不同。對於8051單片機,目前廣泛使用的是C51語言。
C51語言的基本語法與標准C語言相同,只是在標准C語言的基礎上進行了適合於8051內核單片機硬體的擴展。深入理解C51語言對標准C語言的擴展部分以及它們的不同之處,是掌握C51語言的關鍵之一。
C51語言與標准C語言的一些差別如下。
(1)庫函數的不同。標准C語言中的,不適合於嵌入式控制器系統的庫函數,被排除在C51語言之外,如字元屏幕和圖形函數,而有些庫函數必須針對8051單片機的硬體特點來做出相應的開發。例如,庫函數printf和scanf,在標准C語言中,這兩個函數通常用於屏幕列印和接收字元,而在C51語言中,主要用於串列口數據的收發。
(2)數據類型有一定區別。在C51語言中增加了幾種針對8051單片機特有的數據類型,在標准C語言的基礎上又擴展了4種類型。例如,8051單片機包含位操作空間和豐富的位操作指令,因此,C51語言與標准C語言相比增加了位類型。
(3)C51語言的變數存儲模式與標准C語言中的變數存儲模式數據不一樣。標准C語言最初是為通用計算機設計的,在通用計算機中只有一個程序和數據統一定址的內存空間,而C51語言中變數的存儲模式與8051單片機的各種存儲器區緊密相關。
(4)數據存儲類型的不同。8051單片機存儲區可分為內部數據存儲區、外部數據存儲區以及程序存儲區。內部數據存儲區可分為3個不同的C51存儲類型:data、idata和bdata。外部數據存儲區分為2個不同的C51存儲類型:xdata和pdata。程序存儲區只能讀不能寫,可能在8051單片機片內或在片外,C51語言提供的code存儲類型用來訪問程序存儲區。
Ⅱ C語言與單片機C語言的區別 急求
單片機c語言比起普通C語言增加了一些基本的指令,變數的賦值是16進制,當然單片機c語言只牽涉到普通c語言的基礎部分。具體體現在:
1、單片機中C的語法一般都對 ANSI C有些擴展,及一些特殊寫法 如C51擴展的 data xdata bit sbit 一類的,還有一些中斷程序寫法 void int() interrput 1 一類的。
2、C是一門語言,由對應平台的編譯器編譯成對應平台匯編的程序,各平台的匯編不一樣,當然編譯器也不一樣 DOS上的TC2 TC3 WINDOWS上的VC 8051的C51都有自已的編譯器 。具體區別是由編譯器決的,只能參考對應的編譯手冊,即使同種平台不同的編譯器對C的擴展也有不同。
3、單片機c語言編程是基於C語言的單片機編程。單片機的C語言採用C51編譯器(簡稱C51)。由C51產生的目標代碼短,運行速度高,存儲空間小,符合C語言的ANSI標准,生成的代碼遵循Intel目標文件格式,而且可與A51匯編語言PL/M51語言目標代碼混合使用。
C51本質就是C,是為在單片機上使用C而出來的,如果C不牢固,還是多掌握一點C再學C51,不過新增的知識也不少,而且基本上跟C無關。
4、C只是一種高級語言。它除具有一般高級語言的功能特性外,它可以很好的操作底層的硬體介面。在C語言的基礎上,如果你把一些單片機的埠或特殊功能寄存器加於定義,使之方便於在 寫語句的時候,直接直觀的編寫。這樣就差不多是單片機C語言。
C語言的特性差不多都可以用於單片機C語言,因為它們的編譯機理都是一樣的。
(2)C51編譯器在標准C的基礎上擴展閱讀:
C語言:
C語言是一門通用計算機編程語言,廣泛應用於底層開發。C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲器、產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語言。
盡管C語言提供了許多低級處理的功能,但仍然保持著良好跨平台的特性,以一個標准規格寫出的C語言程序可在許多電腦平台上進行編譯,甚至包含一些嵌入式處理器(單片機或稱MCU)以及超級電腦等作業平台。
C語言是一門面向過程的計算機編程語言,與C++,Java等面向對象的編程語言有所不同。
其編譯器主要有Clang、GCC、WIN-TC、SUBLIME、MSVC、Turbo C等。
單片機的C語言:
單片機軟體設計使用C語言作為編程開發軟體,採用模塊化的程序結構,設計了按鍵模塊程序、RFID模塊程序、日歷時鍾模塊程序、GPRS模塊程序、顯示存儲模塊程序等,並編寫系統主程序,將五個程序模塊組合在一起,實現單片機控制系統的整體功能。
51單片機支持三種高級語言,即PL/M,C和BASIC。C語言是一種通用的程序設計語言,其代碼率高,數據類型及運算符豐富,並具有良好的程序結構,適用於各種應用的程序設計,是目前使用較廣的單片機編程語言。
單片機的C語言採用C51編譯器(簡稱C51)。有C51產生的目標代碼短,運行速度高,所需存儲空間小,符合C語言的ANSI標准,生成的代碼遵循Intel目標文件格式,而且可與A51匯編語言或PL/M51語言目標代碼混合使用
C語言-網路
單片機C語言-網路
Ⅲ C51變數的設置與標准C語言變數的設置有何不同
C51的語法完全符合標准C語言語法的,所以變數的設置基本上相同。不同點是C51可以設置變數的存儲區,默認為內部RAM,即data,可省略。其它,idata為間址定址區,bdata為位定址區,xdata為外部數據存儲區,code為程序存儲區。
例如:unsigned char xdata num=20;
變數num為外部數據存儲區。
Ⅳ Linux GNU C 和 ANSI C 的區別
Linux環境下的C編程主要依賴GNU C編譯器,它在標准C的基礎上進行了一系列擴展,增強了C語言的功能。以下是GNU C與ANSI C的一些關鍵區別:
1.
零長度和變數長度數組:GNU C允許使用零長度數組,這對於處理變長數據結構非常有用。例如,你可以定義一個不分配內存的數組,僅用於指明數據結構的結構。
2.
Case范圍:GNU C支持case x…y的語法,擴展了標准C的case語句范圍,使得程序更加靈活。
3.
語句表達式:GNU C中的括弧復合語句被看作表達式,這使得在更廣泛的上下文中使用復雜的控制結構成為可能。
4.
Typeof關鍵字:GNU C允許使用typeof獲取變數類型,這在定義宏時很有用,避免了傳遞類型作為參數的繁瑣。
5.
可變參數宏:GNU C支持可變參數宏,使得函數參數的數量可以根據需要動態調整,如printf函數在宏中的應用。
6.
標號元素:GNU C允許數組和結構體的初始化值按任意順序,提供了更大的靈活性。
7.
當前函數名:GNU C提供了__FUNCTION__和__PRETTY_FUNCTION__來獲取當前函數名,C99的__func__更推薦使用。
8.
特殊屬性聲明:GNU C支持如noreturn、format等屬性,用於優化代碼和自定義檢查方法。
9.
內建函數:GNU C提供了大量內建函數,包括對標准庫函數的優化版本和一些特定用途的函數,如返回地址和常數檢測。
10.
兼容性與擴展:如果使用「-ansi–pedantic」選項,gcc會限制使用GNU擴展,如上述的某些特性可能不再可用。
以上是GNU C相對於標准C的主要擴展點,這些特性在Linux內核編程中發揮著重要作用。
Ⅳ c51對於標準的c語言擴展了哪些數據類型
1. `bit`:用於聲明位變數,例如:`bit bit1;`
2. `sbit`:用於聲明特殊寄存器位變數,例如:`sbit bit1 = P1^0;`
3. `sfr`:用於聲明特殊功能寄存器(8位),例如:`sfr P1 = 0x90;`
4. 狀態數據類型:包括`unsigned`、`signed`、`char`、`int`、`float`、`double`等,這些在標准C語言中已存在。
5. 擴展關鍵字:
- `data`:用於指定存儲類型為數據存儲區,例如:`data volatile unsigned char led;`
- `bdata`:用於指定存儲類型為數據存儲區,且數據為位元組訪問,例如:`bdata volatile unsigned char led;`
- `pdata`:用於指定存儲類型為數據存儲區,且數據按字訪問,例如:`pdata volatile unsigned int led;`
- `xdata`:用於指定存儲類型為外部數據存儲區,例如:`xdata volatile unsigned int led;`
- `idata`:用於指定存儲類型為內部數據存儲區,例如:`idata volatile unsigned int led;`
- `code`:用於指定存儲類型為代碼存儲區,例如:`code unsigned char led;`
- `small`、`compact`、`large`:用於指定數據模型,影響寄存器分配和堆棧大小,例如:`#pragma optsize-`(禁用優化時使用)和`#pragma optsize+`(啟用優化時使用)。
- `interrup`:用於聲明中斷服務函數,例如:`void __interrupt __using(void) intr_handler(void);`
- `using`:用於指定中斷向量,例如:`#pragma using=0x00;`
- `reentrant`:用於指定函數為可重入的,例如:`void reentrant func(void);`
Ⅵ 在標準的C語言的數據類型基礎上,C51加入了哪些特殊類型取值范圍
1. bit類型:C51語言中,bit類型用於聲明位變數,其取值范圍通常是0或1。
2. sbit類型:sbit是特殊寄存器位變數的聲明方式,它允許程序員直接訪問和操作特定寄存器的一位。
3. sfr類型:sfr用於聲明特殊功能寄存器(Special Function Register,SFR),這些寄存器是單片機硬體上的一部分,用於控制和訪問單片機的各種外設和功能。其取值范圍涵蓋了所有特殊功能寄存器的地址空間。
4. 擴展關鍵字:C51還包含了一些擴展的關鍵字,如data、bdata、pdata、xdata、idata、code等,這些關鍵字用於指定不同類型的數據存儲區,以適應不同的編程需求和優化內存使用。
5. 數據類型:除了上述特殊類型,C51還提供了常見的數據類型,如small、compact、large,這些用於指定編譯器生成代碼的模型,影響數據存儲和訪問的方式。
6. interrupt關鍵字:在C51中,使用interrupt關鍵字可以聲明中斷服務函數,它是處理中斷的主要方式。
7. using關鍵字:using用於指定寄存器用於訪問內存地址,這在訪問外部RAM時特別有用。
8. reentrant關鍵字:reentrant用於說明一個函數是可重入的,這意味著它可以被中斷服務函數多次調用而不會產生沖突。這主要應用於中斷服務函數,確保它們可以安全地被多個中斷同時調用。