單片機c語言指針
1. 單片機c語言char和int什麼區別啊
在單片機C語言中,char和int都是數據類型,但它們的數據范圍和作用有很大的區別。
char類型通常被用來表示字元型數據,比如字母、數字、符號等。在單片機中,char類型通常佔用1個位元組(8位),其數據范圍一般是-128到127或0到255。char類型的變數通常用於存儲單個搭態首字元或字元串。
int類型通常被用來表示整型數據,比如整數。在單片機中,int類型的大小通常是2個位元組(16位),其數據范圍一般是-32768到32767或0到65535。int類型的變數通常用於存儲整數型閉殲數據。
因此,char和int的區別主要在於數據范圍和作用。在單片機C語言中,char類型通常用於存儲字元型數據,而int類型則用於存儲整型數據。需要注意的是,char類型的變數可知數以通過強制類型轉換(如(int)ch)轉換為int類型的變數,但可能會導致數據精度的損失。
2. 51單片機中C語言int能轉換為unsigned char 指針類型嗎怎麼轉換
1、可以轉換,強制轉換就行。例如:
int a=100;
unsigned char * c = (unsigned char *)a;
2、強制類型轉換
當操作數的類型不同,而且不屬於基本數據類型時,經常需要強制類型轉換,將操作數轉化為所需要的類型。強制類型轉換具有兩種形式,稱轎悉乎為顯式強制轉換和隱式強制類型轉換。
顯式強制類型轉換
顯式強制類型轉換需要使用強制類型轉換運算符,格式如下:
type(<expression>)
或
(type)<expression>
其中,type為類型描述符,如int,float等。<expression>為表達式。經強制類型轉換運算符運算後,返回一個具有type類型的數值,這種強制類型轉換操作並不改變操作數本身,閉悉運算後操作數本身未改變,例如:
int nVar=0xab65;
char cChar=char (nVar);
上述強制類型轉換的結果是將整型值0xab65的高端兩個位元組刪掉,將低端兩個位元組的內容作為char型數值賦值給變陸缺量cChar,而經過類型轉換後nVar的值並未改變。
3. 單片機C語言中 指針問題
getbit是接收一位的子函數攜胡滲吧。
send+2+length是運算當前接收的1byte的存儲地址的。
接收的數據是小端在前的,每接收一位後,通過<<j左移到當前應存儲的位,然後與之前接收的數據辯脊進行或運算,就把這一位存到指定內存做芹里去了。
4. 單片機C語言中是否可把指針和數組為位類型為什麼
不可以的.標准c語言中沒有位類型的關鍵字.位類型只是針對keil c進行的擴展.這是為了適應51單片機因ram空間小而特殊擴展出來的. c語言不是專為51這種或頌單片機服務的.所以它沒有這種功能.特殊編譯器(如keil c)可以造出這樣的位類型.是因為51單衫悉鄭片機有位空間,為了能讓用戶使用這個空間,keil c進行的特殊的處理. 而且根據基礎知識,數陸迅據的最小單元就是位元組了.也就是說c語言針對的最小數據類型就是位元組.一個位元組是8位.說明位比位元組還要小.所以c語言里的數組和指針不能處理這樣的單元. 不過把只是擴展出來,c語言為了解決這樣的問題,可以使用位域.
5. C語言,單片機主要運用到那些
在單片機的開發應用中,已逐漸開始引入高級語言,
C語言就是其中的一種。對用慣了匯編的人來說,總覺得高級語言』可控性』不好,不如匯編那樣隨心所欲。
但是只要我們掌握了一定的C語言知識,有些東西還是容易做出來的,以下是筆者實際工作中遇到的幾個問題,希望對初學C51者有所幫助。
一、C51熱啟動代碼的編制
對於工業控制計算機,往往設有有看門狗電路,當看門狗動作,使計算機復位,這就是熱啟春悔動。
熱啟動時,一般不允許從頭開始,這將導致現有的已測量到或計算到的值復位,導致系統工作異常。
因而在程序必須判斷是熱啟動還是冷啟動,常用的方法是:確定某內存單位為標志位(如0x7f位和0x7e位),
啟動時首先讀該內存單元的內容,如果它等於一個特定的值(例如兩個內存單元的都是0xaa),就認為是熱啟動,
否則就是冷扒虧正啟動,程序執行初始化部份,並將0xaa賦與這兩個內存單元。
根據以上的設計思路,編程時,設置一個指針,讓其指向特定的內存單元如0x7f,然後在程序中判斷,程序如下:
voidmain()
{chardata*HotPoint=(char*)0x7f;
if((*HotPoint==0xaa)&&(*(--HotPoint)==0xaa))
{/*熱啟動的處理*/
}
else
{HotPoint=0x7e;/*冷啟動的處進
*HotPoint=0xaa;
*(++HotPoint)=0xaa;
}
/*正常工作代碼*/
}
然而實際調試中發現,無論是熱啟動還是冷啟動,開機後所有內存單元的值都被復位為0,當然也實現不了熱啟動的要求。這是為什麼呢?原來,用C語言編程時,開機時執行的代碼並非是從main()函數的第一句語句開始的,在main()函數的第一句語句執行前要先執行一段』起始代碼』。正是這段代碼執行了清零的工作。C編譯程序提供了這段起始代碼的源程序,名為CSTARTUP.A51,打開這個文件,可以看到如下代碼:
.
IDATALENEQU80H;thelengthofIDATAmemoryinbytes.
.
STARTUP1:
IFIDATALEN<>0
MOVR0,#IDATALEN-1
CLRA
IDATALOOP:MOV@R0,A
DJNZR0,IDATALOOP
ENDIF
.
可見,在執行到判斷是否熱啟動的代碼之前,起始代碼已將所有內存單元清零。如何解決這個問題呢?好在啟動代碼是可以更改的,方法是:修改startup.a51源文件,然後用編譯程序所附帶的a51.exe程序對startup.a51編譯,得到startup.obj文件,然後用這段代碼代替原來的起始代碼。具體步驟是(設C源程序名為HOTSTART.C):
修改startup.a51源文件(這個文件在C51LIB目錄下)。
執行如下命令:
A51startup.a51得到startup.obj文件。將此文件拷入HOTSTART.C所在目錄。
將編好的C源程序用C51.EXE編譯好,得到目標文件HOTS
TART.OBJ。
用L51HOTSTART,STARTUP.OBJ命令連接,得到絕對目標文件HOTSTART。
用OHS51HOTSTART得到HOTSTART.HEX文件,即可。
對於startup.a51的修改,根據自已的需要進行,如將IDATALENEQU80H中的80H改為70H,就可以使6F到7F的16位元組內存不被清零。
二、直接調用EPROM中已固化的程序
筆者用的模擬機,由6位數碼管顯示,在內存DE00H處放顯示子程序,只要將要顯示的數放入顯示緩沖區,然後調用這個子程序就可以使用了,匯編指令為:
LCALL0DEOOH
在用C語言編程時,如何實現這一功能呢?C語言中有指向函數的指針這一概念,可以利空租用這種指針來實現用函數指針調用函數。指向函數的指針變數的定義格式為:
類型標識符(*指針變數名)();
在定義好指針後就可以給指針變數賦值,使其指向某個函數的開始存地址,然後用
(*指針變數名)()即可調用這個函數。如下例:
voidmain(void)
{
void(*DispBuffer)();/*定義指向函數指針*/
DispBuffer=0xde00;/*賦值*/
for(;;)
{Key();
DispBuffer();
}
}
三、將浮點數轉化為字元數組
筆者在編制應用程序時有這樣的要求:將運算的結果(浮點數)存入EEPROM中。我們知道,浮點數在C語言中是以IEEE格式存儲的,一個浮點數佔用四個位元組,例如浮點數34.526存為(160,26,10,66)這四個數。要將一個浮點數存入EEPROM,實際上就是要存這四個數。那麼如何在程序中得到一個浮點數的組成數呢?
浮點數在存儲時,是存儲連續的位元組中的,只要設法找到存儲位置,就可以得到這些數了。可以定義一個void的指針,將此指針指向需要存儲的浮點數,然後將此指針強制轉化為char型,這樣,利用指針就可以得到組成該浮點數的各個位元組的值了。具體程序如下:
#defineucharunsignedchar#defineuintunsignedintvoidFtoC(void)
{floata;
uchari,*px
ucharx[4];/*定義字元數組,准備存儲浮點數的四個位元組*、
void*pf;
px=x;/*px指針指向數組x*/
pf=&a;/*void型指針指向浮點數首地址*/
a=34.526;
for(i=0;i<4;i++)
{*(px+i)=*((char*)pf+i);/*強制void型指針轉成char型,因為*/
}/*void型指針不能運算*/
}
如果已將數存入EEPROM,要將其取出合並,方法也是一樣,可參考下面的程序。
#defineucharunsignedchar#defineuintunsignedint
voidCtoF(void)
{floata;
uchari,*px
ucharx[4]={56,180,150,73};
void*pf;
px=x;
pf=&a;
for(i=0;i<4;i++)
{*((char*)pf+i)=*(px+i);
}
}
以上所用C語言為FRANKLINC51VER3.2。
6. 單片機C51,C語言的一個指針問題
P0 = *((uint8 data*)&ledBuff+i);
ledBuff是緩沖區的起始位置,它的類檔敬神型你可以從函數外面看到,因為它是一個全局變數。
&ledBuff是取ledBuff的地址,
(uint8 data*)&ledBuff是把取得的地址強制轉換為uint8 data類型的指針。
((uint8 data*)&ledBuff+i是將這個指針位移,偏移量是i
*((uint8 data*)&ledBuff+i)最後加*號是將便宜後行虧的地稿液址中的值取出來,最終賦值給了P0.
這里P0是一個埠。
7. C語言指針問題,單片機控制1602
根據圖片所示,寫入數據後扮譽啟,游標會自動左移或者右移(你的設置是右移)。虛碧所以這就解釋了為什麼廳如你要寫的數組要程序自加,1602的地址卻不需自加。希望對你有幫助
8. C語言的指針,在寫51單片機程序用得上嗎
可以的。
在51單片機的嵌入式C語言中,指針同樣是被支持的。
所哪配以在單片機上一樣可以使用指針操作,具體使用方法,與標准C語言並沒有不同。
不過需要注意的是,使用指針代表著間接定址,相對變數李談指的直接定址,速度要稍慢一些。而單片機運算速度較慢,大量使用指針有可能會降低執行效率,影響效果。所以除非必要,還是少侍悄用指針。
9. 學單片機C語言編程也要學指針嗎學了有什麼好處不學不行嗎
必須要學的,如果你想夠用就行,可以不學,但是隨著你接觸的東西多了,學的東西多了,你就必須要會指針這種東西,轎敬念不然後期發展很困難。就像樓上說的,會閉困指針,你才能成為真正的稿核高手
10. 單片機c語言怎樣用指針訪問code區數組中的某一元素
void CHcnkDlg::OnButton1()
{
// TOD Add your control notification handler code here
char str[8]; //定顫友義一個字元串數組 ,用來存放列表框1中輸入的內容
char *ptr; //定義一個指針,用來處理字元串數組中的元素
char cResult[8]; //定義一個字元串,用來存放列表框1中的數據經過處理後顯示在列表框2中帶凱的
內容
m_List1.GetLBText(str,; //調用GetLBText()函數,獲得列表框1輸茄行槐入的內容,存放在字元串
數組str 中
ptr=str+2;
*ptr=0;
m_List2=(LPCTSTR)cResult; //將結果字元串賦給對象m_List2
UPdateData(FALSE); //更新屏幕
}
希望可以幫助到你