導航:首頁 > 操作系統 > 單片機struct

單片機struct

發布時間:2022-05-21 19:09:14

『壹』 ARM單片機的頭文件如何用結構體定義地

下面我們以ARM Cortex-M0內核單片機LPC1114的頭文件lpc11xx.h文件進行說明。

1.先說兩句

lpc11xx.h文件是lpc11xx系列單片機包含的頭文件。這個文件的作用和51單片機中的reg51.h頭文件是一個性質,都是用來定義寄存器在單片機中的地址的。

你現在就可以打開reg51.h文件和lpc11xx.h文件看看,對比後你會發現兩個主要的區別,首先是lpc11xx.h文件的寄存器定義是用結構體的形式,而reg51.h文件中,寄存器的定義都是一條一條的很直接的地址定義。然後是reg51.h文件中有sfr這樣的「偽c語言」,而lpc11xx.h中用的是標準的c語言。C語言的最大用武之地就是單片機,要想學c,就在單片機上學,要想學單片機,就先入門c語言。兩者相輔相成的學,效果最好。學以致用,才是學習的最終目標。

2.lpc11xx.h文件中如何定義寄存器地址?

在文件中,定義寄存器地址用到了一下幾方面的c語言基礎知識:

結構體;

結構體指針;

宏定義#define

關鍵字typedef

關鍵字volatile

關鍵字const

lpc11xx.h文件中,把每個模塊都定義了一個結構體,這些模塊有SYSCON、IOCON、UART、GPIO、SSP、I2C、WDT、ADC等。

例如,下面是ADC模塊的結構體定義:

typedef struct
{
__IO uint32_t CR;
__IO uint32_t GDR;
uint32_t RESERVED0;
__IO uint32_t INTEN;
__IO uint32_t DR[8];
__I uint32_t STAT;
} LPC_ADC_TypeDef;

結構體的定義有三種形式,我們這里使用的是「直接說明變數」的形式。

lpc11xx.h文件的第566~584行,給每個模塊的結構體變數定義了結構體指針,並加了宏定義#define,為的是以後寫程序時書寫方便。

把滑鼠放到uint32_t上面,單擊滑鼠右鍵,在彈出的菜單中選擇「Go To Definition Of 『uint32_t』」,如下圖所示:

選擇後,就會跳到它的定義之處,如下圖所示:

typedef是類型重定義關鍵字,所以實際上,CR寄存器的定義是這樣的:

__IO unsigned int CR;

按照同樣的方法,可以找到__IO的定義為:

所以,CR寄存器定義實際上是:

volatile unsigned int CR;

volatile關鍵字的作用是為了讓編譯器不要優化這個變數。

unsigned int關鍵字,用來定義無符號的整形變數。

這時候,有人會問,為什麼不直接寫成這樣呢?答:為了閱讀方便。

__IO uint32_t CR;

看到這條語句,我們就會知道,CR寄存器是一個「32位的可讀可寫寄存器」。

volatile unsigned int CR;

同樣的這句話,我們對它的了解就不是那麼一目瞭然了。

3.如何查看每個寄存器的地址?

上面講到,寄存器的地址是由結構體和結構體指針定義的。現在我們來驗證一下它的正確性。

我們隨便找個寄存器,比如ADC模塊的INTEN寄存器(ADC中斷允許寄存器),打開LPC1114的用戶手冊,找到第25章ADC模塊部分,如下圖所示:

從上面圖中,可以看到INTEN的寄存器的地址是0x4001C00C,接下來,我們打開lpc11xx.c文件來驗證一下吧。

打開lpc11xx.c文件,找到ADC模塊的結構體,如下圖所示:

然後再找到LPC_ADC_TypeDef的結構體指針,如下所示:

結構體指針就是用來指向一個地址的,我們來看看上面語句中的LPC_ADC_BASE是什麼:

再看看上條語句中的LPC_APB0_BASE是什麼:

現在終於挖到底了,原來LPC_ADC_TypeDef指針指向的地址為:

0x40000000+0x1C000=0x4001C000

c語言基礎知識:結構體的第一個變數的地址=結構體指針的地址。

所以結構體的第一個變數地址就是0x4001C000,INTEN前面有3個4位元組的變數,所以INTEN的地址就是0x4001C00C。

驗證完畢。

4.程序中,如何操作寄存器?

C語言基礎知識:用結構體變數指針訪問結構體中的變數,形式有兩種:

*結構體指針變數.變數名

結構體指針變數->變數名

還是拿INTEN寄存器為例,假設我們要給這個寄存器寫0x837,可以這樣寫:

*LPC_ADC.INTEN=0x837;

LPC_ADC->INTEN=0X837;

以上兩種形式,在寫程序的時候,都可以用。人們習慣用第二種形式。

『貳』 單片機C語言中結構體的表達式

c語言不等號是用
!=,比如(a!=b)
另外根據實際使用情況,還可以用==判斷,然後取反,(a!=b)
還可以寫成(!(a==b))
再然後,c語言比較靈活的地方,(a-b)也可以用來判斷兩數是否相等(但不建議這樣用)。這個實際上是判斷(a-b)的結果是不是等於0,如果兩數相等,結果等於0,表示「假」,如果不等,結果非0,表示真。

『叄』 單片機 data struct _m m;是什麼意思

data我記得好像是51單片機的那啥ide特有的關鍵字,作用自己去找找。
struct _m 是個結構體,在這之前肯定是有定義過的。
C語言里,如果沒有使用typedef,那麼在使用結構體之前,結構體名稱前必須加關鍵字struct。
這個是語法問題,回去補一下這部分知識。

『肆』 單片機c語言編程

單片機C語言程序設計入門課程,說起來容易,說起來難。學習單片機C語言,首先要了解這兩個東西是什麼。單片機入門編程主要是學習C語言,其次是電路和編程語言。單片機C語言程序設計學習中必讀的模擬電、數字電、電路三本書,為接下來的學習做鋪墊。看書的目的是因為網上教程太多,容易出現偏差。其實只要能懂電路原理,就能開發單片機軟體。簡介單片機又稱單片微控制器,不是執行某種邏輯功能的晶元,而是將一個計算機系統集成到一個晶元中。相當於一台微型計算機,與計算機相比,單片機只是缺少I/O設備。綜上所述,晶元變成了電腦。它體積小、重量輕、價格低,為研究、應用和開發提供了便利條件。同時,學習使用單片機是了解計算機原理和結構的最佳選擇。單片機已經廣泛應用於智能儀器、實時工業控制、通訊設備、導航系統、家用電器等領域。自20世紀90年代以來,單片機技術得到了發展。隨著時代的進步和科技的發展,這項技術的實際應用也越來越成熟,單片機被廣泛應用於各個領域。如今,人們越來越重視單片機在智能電子技術中的發展和應用,單片機的發展進入了一個新的時期。無論是自動測量的實踐,還是智能儀器的實踐,都可以看到單片機技術的身影。在當前的產業發展過程中,電子產業是一個新興的產業。在工業生產中,人們已經成功地應用了電子信息技術,將電子信息技術與單片機技術相結合,有效地提高了單片機的應用效果。作為計算機技術的一個分支,單片機技術在電子產品領域的應用豐富了電子產品的功能,為智能電子設備的開發和應用提供了新的途徑,實現了智能電子設備的創新和發展。以上內容參考:網路-單片機
你應該先學習C語言。你可以讀譚浩強和單片機的書,循序漸進。別擔心。基礎好,什麼都能說。
如果你沒學過微機原理,建議你先學完再買本上海馬超的書,一周就能看懂了~
不認同無意義的光。《C編程》確實創造了一時的輝煌,這種輝煌很可能會延續下去,但不代表就是最好的。這本書之所以流行,是因為當時沒有辦法學習C,這本書很好理解。但是現在這本書太落後了,甚至3版還在用老標准,現在大家普遍用C99標准。老標准不能用Dev C編譯而且好像提問者應該知道C的基礎,推薦《單片機C語言編程及實例》這本書。直接搜索就能找到PDF版本的下載。-馬克·提埃洛
看譚浩強老師的。清華大學出版的《飢餓》。

『伍』 單片機 結構體 數據結構 會拖慢運行速度么

當然了,但現在的單片機速度都很快,這些速度上的損失可以忽略的。

『陸』 求一份單片機C語言編程的32個關鍵字和9種控制語句的主要作用表

auto
:聲明自動變數
short
:聲明短整型變數或函數
int:
聲明整型變數或函數
long
:聲明長整型變數或函數
float:聲明浮點型變數或函數
double
:聲明雙精度變數或函數
char
:聲明字元型變數或函數
struct:聲明結構體變數或函數
union:聲明共用數據類型
enum
:聲明枚舉類型
typedef:用以給數據類型取別名
const
:聲明只讀變數
unsigned:聲明無符號類型變數或函數
signed:聲明有符號類型變數或函數
extern:聲明變數是在其他文件中聲明
register:聲明寄存器變數
static
:聲明靜態變數
volatile:說明變數在程序執行中可被隱含地改變
void
:聲明函數無返回值或無參數,聲明無類型指針
if:條件語句
else
:條件語句否定分支(與
if
連用)
switch
:用於開關語句
case:開關語句分支
for:一種循環語句
do
:循環語句的循環體
while
:循環語句的循環條件
goto:無條件跳轉語句
continue:結束當前循環,開始下一輪循環
break:跳出當前循環
default:開關語句中的「其他」分支
sizeof:計算數據類型長度
return
:子程序返回語句(可以帶參數,也可不帶參數)循環條件

『柒』 51單片機c語言編程中,有沒有隻定義p2.1到p2.6的寫法不要一個個的定義。

對於51單片機而言是不能一次性定義單獨的一個IO口的某些位的,Keil裡面沒有提供相應的處理方法,有些單片機的C語言有此功能,用到了聯合和結構的方式。比如在瑞薩的單片機C語言上可以這樣定義:

union{/*EBR1*/
unsignedcharBYTE;/*ByteAccess*/
struct{/*BitAccess*/
unsignedcharEB7:1;/*EB7*/
unsignedcharEB6:1;/*EB6*/
unsignedcharEB5:1;/*EB5*/
unsignedcharEB4:1;/*EB4*/
unsignedcharEB3:1;/*EB3*/
unsignedcharEB2:1;/*EB2*/
unsignedcharEB1:1;/*EB1*/
unsignedcharEB0:1;/*EB0*/
}BIT;
}Port2

『捌』 在單片機C語言中如何對變數的某一位進行操作或賦值。

在C語言中,一般有兩種方法來操作位,一種是使用C語言提供的位運算操作符,一種是使用位域。

1、使用位域

在C語言中定義位域的一般格式如下:

struct位域結構名
{位域列表};

struct:在C語言中定義位域所使用的關鍵字是struct。

位域結構名:是一個C語言中的標識符,有字母、數字、下劃線組成,而且第一個字元必須是字母或者下劃線。

位域列表:組其中位域列表的形式為: 類型說明符 位域名:位域長度

下面的示例代碼,通過位域來計算IEEE754浮點數編碼中單精度數的最大值 、最小值和最小弱規范數。

#include<stdio.h>
typedefstructFP_SINGLE
{
unsigned__int32fraction:23;
unsigned__int32exp:8;
unsigned__int32sign:1;
}fp_single;
intmain()
{
floatx;
fp_single*fp_s=(fp_single*)&x;
fp_s->sign=0;
fp_s->exp=0xfe;
fp_s->fraction=0x7fffff;
printf("float最大數:%le ",(double)x);
fp_s->sign=0;
fp_s->exp=0x1;
fp_s->fraction=0x0;
printf("float最小數:%le ",(double)x);
fp_s->sign=0;
fp_s->exp=0;
fp_s->fraction=0x1;
printf("float最小弱規范數:%le ",(double)x);
return0;
}

2、使用位運算符

C語言中的位運算符有一個基本的常識,即只能操作整數,不能操作浮點數,因為浮點數是使用IEEE754編碼的,使用位操作數沒有任何意義。

C語言提供的位運算符列表:
&按位與如果兩個相應的二進制位都為1,則該位的結果值為1,否則為0
|按位或兩個相應的二進制位中只要有一個為1,該位的結果值為1
^按位異或若參加運算的兩個二進制位值相同則為0,否則為1
~取反~是一元運算符,用來對一個二進制數按位取反,即將0變1,將1變0
<<左移用來將一個數的各二進制位全部左移N位,右補0
>>右移將一個數的各二進制位右移N位,移到右端的低位被舍棄,對於無符號數,高位補0
閱讀全文

與單片機struct相關的資料

熱點內容
安陽少兒編程市場 瀏覽:496
雲伺服器建設原理 瀏覽:258
javajunit4for 瀏覽:845
華為伺服器如何進陣列卡配置 瀏覽:435
apache伺服器ip地址訪問 瀏覽:718
如何買到安卓手機預裝軟體 瀏覽:537
冤罪百度雲不要壓縮 瀏覽:87
蘇州雲存儲伺服器 瀏覽:175
解壓收納原聲 瀏覽:386
java注冊驗證 瀏覽:375
火花app怎麼上推薦 瀏覽:981
什麼app能游戲投屏到電視上 瀏覽:455
伺服器託管到雲端是什麼意思 瀏覽:836
app保存草稿怎麼用 瀏覽:808
安卓如何進入proumb 瀏覽:144
主機虛擬雲伺服器 瀏覽:619
刪除分區加密的空間會不會恢復 瀏覽:706
京東app客戶上門怎麼看搜索量 瀏覽:741
怎麼在農行app購買黃金 瀏覽:46
c型開發板和單片機 瀏覽:146