1. LAB100.C(12): error C216: subscript on non-array or too many dimensions 原程序如下:
#include#include voiddelay(int);unsignedcharcodedis_code[8]={0x28,0x7e,0xa2,0x62,0x74,0x61,0x21,0x7a};main(){inti,j;P2=0xff;while(1){P2=0x7f;for(i=0;i<8;i++){P0=dis_code[i];P2=_crol_[j,1];j=P2;delay(1);}}}voiddelay(intx){inti;for(i=0;i 問題在于P2=_crol_[j,1];
應(yīng)該改為P2=_crol_(j,1);
2. 從網(wǎng)上COPY的程序執(zhí)行類似的功能,有時候如果現(xiàn)象沒出現(xiàn),或者不明顯,可以調(diào)整下延遲函數(shù)。
3. 數(shù)碼管的掃描顯示0—7,延遲函數(shù)的延遲時間在1ms左右,是通過人眼的視覺暫留而產(chǎn)生的現(xiàn)象,如果延遲函數(shù)設(shè)置的太大,則看不到持續(xù)顯示0—7的現(xiàn)象。
4. 用KEILC51調(diào)試程序時,出現(xiàn)錯誤提示為“unprintable character 0XA1 skipped”的問題。輸入法的問題。在程序行輸入中文模式下標點符號,不會顯示,但是會出現(xiàn)標題這樣的問題。 打上//馬上就能看到?jīng)]有顯示的標點符號。
5.*** WARNING L16: UNCALLED SEGMENT, IGNORED FOR OVERLAY PROCESS SEGMENT: ?PR?_COMPARE?TESTLCD
說明:程序中有些函數(shù)(或片段)以前(調(diào)試過程中)從未被調(diào)用過,或者根本沒有調(diào)用它的語句。這條警告信息前應(yīng)該還有一條信息指示出是哪個函數(shù)導(dǎo)致了這一問題。只要做點簡單的調(diào)整就可以。不理它也沒什么大不了的。
解決方法:去掉COMPARE()函數(shù),或利用條件編譯#if …..#endif,可保留該函數(shù)并不編譯。6.LAB99.C(19): error C141: syntax error near '{', expected 'const'程序如下:
#include#include sbitLEDP=P1^0;unsignedcharcounter;main(){TMOD=0x01;TH0=0x3C;TL0=0xB0;counter=0x0A;EA=1;ET0=1;TR0=1;while(1){};}voidtimer0_int(void)interrupt{TH0=0x3C;TL0=0xB0;counter--;if((counter)!=0){counter=0x0A;LEDP=~LEDP;}} 問題在中斷函數(shù)的寫法上,C下面51的中斷函數(shù)要這么寫:
voidtimer0_int(void)interruptNusingM其中的N是不同中斷對應(yīng)的中斷號,一般單片機的書上都有說明的,M是這個中斷函數(shù)在存儲空間中所占的bank,一般不要和main函數(shù)的一樣就可以了,而main函數(shù)的在bank0,那么針對51單片機,這個M可以為1,2,3。
7.C51編譯警告“*** WARNING L1: UNRESOLVED EXTERNAL SYMBOL”
*** WARNING L1: UNRESOLVED EXTERNAL SYMBOL
SYMBOL: ?C_START
MODULE: .STARTUP.obj (?C_STARTUP)
*** WARNING L2: REFERENCE MADE TO UNRESOLVED EXTERNAL
SYMBOL: ?C_START
MODULE: .STARTUP.obj (?C_STARTUP)
ADDRESS: 000DH如果你在用C51編譯器出現(xiàn)上面的警告,并且找遍了網(wǎng)上也沒能找出個究竟時,你是否覺得這個問題很難,難得以至于沒人能回答呢?其實這個只是初學(xué)者和粗心者才會犯的錯誤:沒把C文件添加到項目中!另外,還有可能是因為存在沒有被調(diào)用的已經(jīng)定義的函數(shù)。
8.*** WARNING L15: MULTIPLE CALL TO SEGMENT***
原因Warning 15向我們表明了linker發(fā)現(xiàn)了一個函數(shù),這個函數(shù)不僅在main code里被調(diào)用了,而且在ISR(或者被ISR調(diào)用的函數(shù)中)被調(diào)用了?;蛘呤潜煌瑫r被多個ISR同時調(diào)用了。這樣會產(chǎn)生一個問題,就是在此函數(shù)不是一個可重入函數(shù),而當(dāng)此函數(shù)已經(jīng)在執(zhí)行時它可能被另一個ISR所調(diào)用。這樣就會導(dǎo)致結(jié)果是可變的而且很可能會導(dǎo)致一些參數(shù)的錯誤。另一個問題就是本地變量和參數(shù)所使用的內(nèi)存可能被其他函數(shù)的內(nèi)存覆蓋。如果函數(shù)是由中斷所調(diào)用的,則此函數(shù)的內(nèi)存就會被使用。這會引起其它函數(shù)的內(nèi)存錯誤。
舉例來說,對于你的第一個警告,WRITE_GMVLX1_REG是會被多個root所調(diào)用。其被定義在D_GMVLX1.C或者D_GMVLX1.A51中。他不僅會被ISR(或者被ISR調(diào)用的函數(shù))而且也會被MAIN.C中的VSYNC_INTERRUPT函數(shù)所調(diào)用。
解決辦法:
(1)主程序調(diào)用該函數(shù)時禁止中斷,可以在該函數(shù)被調(diào)用時用#pragma disable語句來實現(xiàn)禁止中斷的目的。必須使用OVERLAY指令將該函數(shù)從覆蓋分析中除去。
(2)復(fù)制兩份該函數(shù)的代碼,一份到主程序中,另一份復(fù)制到中斷服務(wù)程序中。
(3)將該函數(shù)設(shè)為重入型。例如:voidmyfunc(void)reentrant{...}這種設(shè)置將會產(chǎn)生一個可重入堆棧,該堆棧被被用于存儲函數(shù)值和局部變量,用這種方法時重入堆棧必須在STARTUP.A51文件中配置。這種方法消耗更多的RAM并會降低重入函數(shù)的執(zhí)行速度。
9.
voiddelay(unsignedchari){while(i--){;}}main(){unsignedchari,k;while(1){i=8;delay(i);i=7;delay(i);k=10;}}編譯器的意思是我那行程序i=7;沒有用,怎么解決這個問題?呢實際上是被編譯了的,調(diào)用函數(shù)時傳遞的的確是7。沒有寫回到 i 倒是事實,因為編譯器認為后面不再用 i 了,所以就沒有回寫。如果你將下面的k=10改成k=i,那么就會將7寫回到i,并且keil編譯器不會直接使用立即數(shù)7,而用一條減1指令,從前面的8減1變成7。
10. 單片機中_crol_函數(shù)的的意思:
_crol_(a,m) 將a循環(huán)左移,步進為m
_cror_(a,n) 將a循環(huán)右移,步進為n11.
if(temp-ret>min_value){min_value=temp-ret;min_id=i;}LAB06.C(72): error C193: '-': illegal op-type(s)
此處需要強制類型轉(zhuǎn)換,因為上面有一定義
unsignedintret[50];unsignedinttemp=0;temp和ret不是同一類型數(shù)據(jù)。
12.
#include"stdafx.h"#include"stdio.h"#include"conio.h"intmain(intargc,char*argv[]){chara[9][9]={{"","","","*"},{"","","*","*","*"},{"","*","*","*","*","*"},{"*","*","*","*","*","*","*"},{"","*","*","*","*","*"},{"","","*","*","*"},{"","","","*"}};inti,j;printf("%c",a[i][j]);return0;}error C242: 'a[][]': too many initializers
如果要使用缺省賦值,則前面的每行不能缺省賦值,只能在最后缺省,也就是你可以對前7行進行完全賦值,后兩行缺省,卻不能每行中缺一些,還缺行. initializer 初始化。
13.Warning 280:’i?unreferenced local variable
說明局部變量 i 在函數(shù)中未作任何的存取操作。解決方法:消除函數(shù)中 i 變量的宣告。
14.Warning 206:’Music3?missing -prototype
說明Music3( )函數(shù)未作宣告,或未作外部宣告