uint8_t / uint16_t / uint32_t /uint64_t数据类型

简介: uint8_t / uint16_t / uint32_t /uint64_t数据类型

uint8_t / uint16_t / uint32_t /uint64_t 是什么数据类型?

在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 中定义的,具体定义在:/usr/include/stdint.h ISO C99: 7.18 Integer types

/ There is some amount of overlap with as known by inet code /

ifndef __int8_t_defined

define __int8_t_defined

typedef signed char int8_t;
typedef short int int16_t;
typedef int int32_t;

if __WORDSIZE == 64

typedef long int int64_t;

else

extension
typedef long long int int64_t;

endif

endif

/ Unsigned. /
typedef unsigned char uint8_t;
typedef unsigned short int uint16_t;

ifndef __uint32_t_defined

typedef unsigned int uint32_t;

define __uint32_t_defined

endif

if __WORDSIZE == 64

typedef unsigned long int uint64_t;

else

extension
typedef unsigned long long int uint64_t;

endif

注意:

必须小心 uint8_t 类型变量的输出,例如如下代码,会输出什么呢?

uint8_t fieldID = 67;
cerr<< "field=" << fieldID <<endl;
结果发现是:field=C 而 不是我们所想的 field=67
这是由于:

typedef unsigned char uint8_t;
uint8_t 实际是一个 char, cerr << 会输出 ASCII 码是 67 的字符,而不是 67 这个数字.

因此,输出 uint8_t 类型的变量实际输出的是其对应的字符, 而不是真实数字.

若要输出 67,则可以这样:

cerr<< "field=" << (uint16_t) fieldID <<endl;
结果是:field=67

同样: uint8_t 类型变量转化为字符串以及字符串转化为 uint8_t 类型变量都要注意, uint8_t类型变量转化为字符串时得到的会是ASCII码对应的字符, 字符串转化为 uint8_t 变量时, 会将字符串的第一个字符赋值给变量.

例如如下代码:

include

include

include

using namespace std;

int main()
{
uint8_t fieldID = 67;

// uint8_t --> string  
string s;  
ostringstream strOStream;  
strOStream << fieldID;  
s = strOStream.str();  
cerr << s << endl;  

// string --> uint8_t  
s = "65";   
stringstream strStream;  
strStream << s;  
strStream >> fieldID;  
strStream.clear();  
cerr << fieldID << endl;  

}
//代码效果参考:http://www.zidongmutanji.com/zsjx/394943.html

上述代码输出的是:

C

6

相关文章
|
1月前
|
计算机视觉 Python
uint16
uint16“【5月更文挑战第14天】”
16 1
|
1月前
|
存储 C语言
计算 int, float, double 和 char 字节大小
计算 int, float, double 和 char 字节大小。
28 3
|
8月前
|
存储 C语言
C 语言实例 - 计算 int, float, double 和 char 字节大小
C 语言实例 - 计算 int, float, double 和 char 字节大小。
44 1
|
11月前
|
编译器
unsigned long int 和 unsigned long一样吗?
unsigned 代表的是无符号的整形数
175 0
|
C++
【C/C++】uin8_t uint16_t uint32_t相互转换
uin8_t uint16_t uint32_t 数据类型相互转换
574 0
|
PyTorch 算法框架/工具 索引
如何将[array([5, 0, 0, 0, 0, 0], dtype=uint32), array([0, 1, 0, 4, 0, 0], dtype=uint32), array([0, 0, 0, 3, 3, 3], dtype=uint32)] 转换成一个torch张量
在这个代码中,我先使用 torch.randperm() 函数生成一个长度为原始张量大小的随机索引序列,并用这个索引序列对原始张量进行重排,得到了打乱后的张量 shuffled_tensor。然后,我使用 torch.split() 函数将 shuffled_tensor 拆分成 3 份子张量,并打印出来以验证是否拆分成功。
264 0
|
编解码 网络协议 5G
【C/C++】uin8_t uint16_t uint32_t uint64_t数据类型解析
为了代码编写和阅读方便,我们通常会将数据类型名称声明为简写方式,即uin8_t/uint16_t/uint32_t/uint64_t,或者UINT8/UINT16/UINT32/UINT64。
1360 1
【C/C++】uin8_t uint16_t uint32_t uint64_t数据类型解析
tdav_converter_video.cxx:49:9: error: ‘uint8’ does not name a type; did you mean ‘uint’?
tdav_converter_video.cxx:49:9: error: ‘uint8’ does not name a type; did you mean ‘uint’?
102 0
int 与 unsigned int
cpp primer  P31 带符号类型和不带符号类型   1、除去布尔型和扩展字符外,其他整型可以划分为带符号的(signed)和无符号的(unsigned)两种。
1121 0
|
Go
Go uint64转化成[]byte
binary.BigEndian.PutUint64(byte切片变量, uint64变量) 链接:https://blog.csdn.net/coledaddy/article/details/71195528 ...
1782 0