一般来说:
8位无符号整型: typedef unsigned char u8;
16位无符号整型:typedef unsigned short u16;
32位无符号整型:typedef unsigned int u32;
64位无符号整型:typedef unsigned long u64;
8位有符号整型: typedef signed char u8;
16位无符号整型:typedef signed short u16;
正常u16的范围为:0-65536;
u32的范围为:0-2^32,数值很大,我也不知道是多少;
u64的范围为:0-2^64,基本是无限大,正常数据都到不了这么大;
但是对于IAR for 8051来说:
u16:0-32768;
u32:0-65536;
u64:0-2^32;
所以,平常我们在其它编译器里面用不到的u64在这个编译器里会经常使用了,因为u32实在太小了
注意,如果你把一个u32的变量A赋值为65533(未超出),然后把它打印出来,你会发现并不是65533,但是你把这个变量除以100再赋值给变量B,再把B打印出来你会发现B是655,说明A的值是没错的,错应该错在printf函数上了;
还有,你如果把A赋值成 -8263,再把它打印出来,你会发现就是 -8263,但是你把它除以100再赋值给B再打印出来发现并不是-82,说明u32并不是包含有符号,而是printf造成的假象;
另外,你如果把u64的变量C赋值成10000000(未超出范围),再打印的时候就需要用%ld而不是%d了,因为u64的定义是unsigned long(无符号长整型);
对于s8和s16暂未测试其范围,有兴趣的可以自己试试。