在nesc的**中,你會看到很多你不認識的資料型別,比如uint8_t等。咋一看,好像是個新的資料型別,不過c語言(nesc是c的擴充套件)裡面好像沒有這種資料型別啊!怎麼又是u又是_t的?很多人有這樣的疑問。論壇上就有人問:以*_t結尾的型別是不是都是long型的?在baidu上查一下,才找到答案,這時才發覺原來自己對c掌握的太少。
那麼_t的意思到底表示什麼?具體的官方答案沒有找到,不過我覺得有個答案比較接近。它就是乙個結構的標註,可以理解為type/typedef的縮寫,表示它是通過typedef定義的,而不是其它資料型別。
uint8_t,uint16_t,uint32_t等都不是什麼新的資料型別,它們只是使用typedef給型別起的別名,新瓶裝老酒的把戲。不過,不要小看了typedef,它對於你**的維護會有很好的作用。比如c中沒有bool,於是在乙個軟體中,一些程式設計師使用int,一些程式設計師使用short,會比較混亂,最好就是用乙個typedef來定義,如:
typedef char bool;
一般來說,乙個c的工程中一定要做一些這方面的工作,因為你會涉及到跨平台,不同的平台會有不同的字長,所以利用預編譯和typedef可以讓你最有效的維護你的**。為了使用者的方便,c99標準的c語言硬體為我們定義了這些型別,我們放心使用就可以了。
按照posix標準,一般整形對應的*_t型別為:
1位元組 uint8_t
2位元組 uint16_t
4位元組 uint32_t
8位元組 uint64_t
附:c99
標準中inttypes.h
的內容
資料型別 uint32 t 型別
整型的每一種都有無符號 unsigned 和有符號 signed 兩種型別 float和double總是帶符號的 在預設情況下宣告的整型變數都是有符號的型別 char有點特別 如果需宣告無符號型別的話就需要在型別前加上unsigned。無符號版本和有符號版本的區別就是無符號型別能儲存2倍於有符號型別...
c 解決無法列印uint8 t 型別變數的問題
將uint8 t 轉化為unsigned 型別 使用一元運算子 和 運算子對應 測試 如下 include include include int main 執行結果如下 可見使用 運算子的原理也是進行型別轉換 把uint8 t 轉為 int 補充知識 c 語言printf列印各種資料型別的方法 u...
資料型別 uint32 t 等型別
1 在寫程式時注意 無符號型別 的使用,各種型別邊界值的情況.如 a 當某個資料不可能為負數時我們一定要考慮用以下型別 unsigned char,unsigned int,uint32 t,size t,uint64 t,unsigned long int,b 當有些資料你不知道是正負時一定不要用...