已知数据类型的含义

meaning of known data types

本文关键字:数据类型      更新时间:2023-10-16

可能重复:
后跟_t(undercore-t)的类型代表什么?

有人知道time_t、uint8_t等中的"t"代表什么吗?它是"类型"吗?第二,为什么要声明这种新类型,例如sizet,它不能只是一个int吗?

是的,t表示类型。

定义新类型的原因是为了将来它们可以更改。随着64位机器已经成为常态,实现方式可以将size_t的位宽更改为64位,而不是仅32位。这是一种让你的程序经得起未来考验的方式。一些小型嵌入式处理器只能很好地处理16位数字。它们的CCD_ 2可能只有16位宽。

一个特别重要的可能是ptrdiff_t,它表示两个指针之间的差异。如果指针大小在将来某个时候发生变化(比如64或128位),您的程序不应该在意。

typedefs的另一个原因是风格。而这些size_t可能只是由定义的

typedef int size_t;

使用名称size_t清楚地表明,变量是指某个事物(容器、内存区域等)的大小。

我认为,它代表类型——一种可能是其他类型的typedef的类型。所以当我们看到int时,我们可以假设它不是任何类型的typedef,但当我们看到uint32_t时,它很可能是某种类型的typedef。这不是一条规则,而是我的观察,尽管有一个例外:wchar_t不是任何其他类型的typedef,但它有_t

是的,它可能代表typetypedef,或者类似的东西。

这些typedef之间的思想是,您确切地指定该变量不是通用int,而是对象的大小/自UNIX epoch以来的秒数/其他;此外,该标准对这些类型的特性做出了具体的保证。

例如,size_t保证包含您可以在C中创建的最大对象的大小,并且可以执行此操作的类型可以根据平台的不同而变化(在Win32 unsigned long上可以,在Win64上需要unsigned long long,而在一些内存非常小的微控制器上,unsigned short可能就足够了)。

对于各种[u]intNN_t,它们是固定大小的整数类型:而对于"普通"int/short/size_t0/。。。该标准没有规定特定的大小,通常你需要一个类型,无论你在哪里编译你的程序,都保证是特定的大小(例如,如果你正在读取二进制文件);这些CCD_ 21是解决这一必要性的解决方案。(顺便说一句,当你只需要一个最小的保证范围时,还有typedef s表示"至少有一定大小的最快整数"。)