c語言中u8,u16,u32

2022-06-23 14:51:14 字數 916 閱讀 1115

u8是unsigned char,u16是unsigned short,u32是unsigned long。

u8,u16,u32都是c語言資料型別,分別代表8位,16位,32位長度的資料型別,一個位元組是8位,所以u8是1個位元組,u16是2個位元組,u32是4個位元組。

可以在stm32庫標頭檔案中找到資料型別的宣告

在stdint.h中:

typedef unsigned char uint8_t;

typedef unsigned short uint16_t;

typedef unsigned long uint32_t;

在stm32f10x.h 中:

typedef uint32_t u32;

typedef uint16_t u16;

typedef uint8_t u8;

擴充套件資料

cpu按照其處理資訊的字長可以分為:8位微處理器、16位微處理器、32位微處理器以及64位微處理器等。字7a686964616fe4b893e5b19e31333431346439、半字是根據處理器的特性決定的,位元組則都是8bit。

stm32是32bit處理器,所以它的字是32bit的(一次處理4位元組長度的資料),半字自然就是16bit(2位元組)。儲存半字型別資料的暫存器由u16型別的變數訪問,但是如果用u8型別變數只能訪問該資料低8位,用u32型別變數讀的時候沒問題,寫的時候會因編譯器的不同而出現偏差。

stm32和傳統的arm相比最大的好處就是不需要對齊,三種型別的資料可以在記憶體中無縫的存放。而傳統的arm7或arm9等是照著地址對齊的,就是說不管8bit或者16bit的資料都要佔用4個位元組的空間,這樣的結果就是造成記憶體的浪費。