arm串口實(shí)現(xiàn) printf 和scanf函數(shù)
1.首先代碼分析:用sourceinsight建立一個(gè)工程:
第一個(gè)文件Ctype.h,注意不會(huì)處理EOF,即end of file。其中的宏定義定義了_U _L _D _C _P _S _X _SP,分別代表的數(shù)字標(biāo)識(shí),這個(gè)數(shù)字標(biāo)識(shí)在Ctype.c中用到。extern unsigned char _ctype[]作用是把_ctype[]聲明為外部的全局變量,不但包含這個(gè)頭文件的多個(gè)文件可以使用,也避免了重復(fù)包含這個(gè)變量的作用。
#define __ismask(x) (_ctype[(int)(unsigned char)(x)]) 作用是_ismask這個(gè)函數(shù)對(duì)輸入的參數(shù)進(jìn)行一個(gè)unsigned char轉(zhuǎn)化到int類型的。
#define isalnum(c) ((__ismask(c)&(_U|_L|_D)) != 0) 作用看名字應(yīng)該是判斷是是否是一個(gè)數(shù)字,不過(guò)我看了ascII表看了1 2 4 位發(fā)現(xiàn)沒(méi)什么特別。
第二個(gè)文件Ctype.c,里面的_ctype里面存的全是八位的獨(dú)熱碼,一共256個(gè)
第三個(gè)文件Div64.h,The semantics of do_div() are,意思是這個(gè)函數(shù)的語(yǔ)義是。
#ifdef __ARMEB__
#define __xh "r0"
#define __xl "r1"
#else
#define __xl "r0"
#define __xh "r1"
#endif
這段代碼的意思是如果定義了arm的endbig則用32位的r0寄存器保存x的高位,同樣的道理else應(yīng)該清楚了。
再往下:#define __asmeq(x, y) ".ifnc " x "," y " ; .err ; .endifnt"表示如果x y 不相等,則會(huì)執(zhí)行.err,而后結(jié)束這個(gè)if分支。
直接看printf這個(gè)函數(shù)的實(shí)現(xiàn),其中參數(shù)列表中有省略號(hào),這是c語(yǔ)言中表示參數(shù)不確定的意思。
評(píng)論