我是初次使用PIC單片機,對PICC的編程規(guī)范不了解,在編譯程序時老是出問題。現(xiàn)在介紹兩個最常見的問題給大家,看看有沒有和我遇到一樣問題的。
錯誤1:變量定義賦值先后順序問題很重要
開發(fā)環(huán)境為MPLAB IDE V7.43 + PICC 。如下兩種代碼書寫方式,在補充完整之后,哪一個會編譯出錯?( flag_sendKeyByte 為全局位變量,已定義過)
A:
flag_sendKeyByte = 0;
unsign char mbit = 0;
B:
unsign char mbit = 0;
flag_sendKeyByte = 0;
使用正常的C語言習慣來看,似乎都沒問題,都是賦值,僅僅是先后位置不一樣。但是在PIC單片機的編譯環(huán)境下,A是錯誤的,B是正確的。
在出現(xiàn)這一編譯錯誤時,我查找了很久。由于初次接觸PIC,了解不多,導致走了很多彎路。最后逐行刪除代碼,逐行修改,最后才發(fā)現(xiàn)是次序錯了。
PIC 單片機的編譯環(huán)境要求變量賦值必須在變量定義之后。而不允許在給一個變量賦值后再去定義另一個變量并賦值。似乎是因為編譯環(huán)境在賦值之前會先處理所有的變量定義。如果檢測到一個變量賦值語句則該函數(shù)或子程序后面的定義它將不再檢查,導致最后編譯的時候出現(xiàn)某些變量未定義。
(注:以上這些分析是我自己揣摩的,可能分析的不對,還請高手指正)
可笑的是,編譯出錯的提示信息卻是亂七八糟的,而不是說存在未定義的變量。下面的提示就是我編譯時提示的,對一個初學者來說,根據(jù)這些提示能找到錯誤源嗎?
Error[000] D:documentsPICtestkeyboardps2.c 387 : probable missing '}' in previous block
Error[000] D:documentsPICtestkeyboardps2.c 388 : undefined identifier: ch
Error[000] D:documentsPICtestkeyboardps2.c 388 : constant expression required
Warning[000] D:documentsPICtestkeyboardps2.c 390 : missing basic type: int assumed
Error[000] D:documentsPICtestkeyboardps2.c 390 : type redeclared
Error[000] D:documentsPICtestkeyboardps2.c 390 : identifier redefined: calc_parity (from line 64)
Error[000] D:documentsPICtestkeyboardps2.c 390 : constant expression required
....
后面還有很多,一直到程序的最后都會提示出錯。把A中的寫法換成B的寫法,編譯就成功了。
感覺這個編譯環(huán)境太不好用了。以前用過C8051F系列的開發(fā)工具,那個就好用多了。把這個問題提出來,提醒初學者別犯我這樣的錯誤。
錯誤2,could not find file 'c018i.o'
在使用MPIDE +MCC18 編譯時經(jīng)常出現(xiàn)下列提示: “could not find file 'c018i.o'”
解決辦法:是因為沒有指定庫的默認路徑。點project->build option->project.在Directories選項卡里,點擊show directories for:右側(cè)的下拉菜單,找到library search path項,選擇new,在新建的項目里指定路徑為c:mcc18lib。點擊確定。再次編譯即可成功。
————————————————————————————————
C語言中變量的聲明必須在一個block的開頭
一個block就是指一對{}大括號包起來的部分
變量的聲明必須緊跟在"{"之后,中間不能夾其它代碼。
還有比如for(char i=0; i< 20 ; i++){ do something...},這在有的編譯器可以用,有的不行
這樣的寫法也是不正確的,會報一個語法錯誤,一個變量未聲明的錯誤
如果想用,但是又不想在block的開頭去聲明這個臨時變量i,可以這樣做:
{ //注意這個大括號
char i;
for(i=0; i< 20 ; i++){ /*do something...*/}
} //注意這個大括號
這樣保證了聲明在block開頭的同時,又能使用局部變量而不用到前面去聲明