已知数据类型的含义
meaning of known data types
可能重复:
后跟_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
。
是的,它可能代表type
或typedef
,或者类似的东西。
这些typedef
之间的思想是,您确切地指定该变量不是通用int
,而是对象的大小/自UNIX epoch以来的秒数/其他;此外,该标准对这些类型的特性做出了具体的保证。
例如,size_t
保证包含您可以在C中创建的最大对象的大小,并且可以执行此操作的类型可以根据平台的不同而变化(在Win32 unsigned long
上可以,在Win64上需要unsigned long long
,而在一些内存非常小的微控制器上,unsigned short
可能就足够了)。
对于各种[u]intNN_t
,它们是固定大小的整数类型:而对于"普通"int
/short
/size_t
0/。。。该标准没有规定特定的大小,通常你需要一个类型,无论你在哪里编译你的程序,都保证是特定的大小(例如,如果你正在读取二进制文件);这些CCD_ 21是解决这一必要性的解决方案。(顺便说一句,当你只需要一个最小的保证范围时,还有typedef
s表示"至少有一定大小的最快整数"。)
- 防止主数据类型C++的隐式转换
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 在C++中打印指向不同基元数据类型的指针的内存地址
- C++浮点数据类型和字符串数据类型无法子到模板函数中
- 如何计算数据类型的范围,例如int
- C++中数据类型修饰符的顺序
- C++LinkedList问题.数据类型之间存在冲突?没有匹配的构造函数
- 特定数据类型的模板类
- 具有多个模板的模板函数,用于特定数据类型(如字符串)?
- 有没有办法提示用户使用哪种数据类型作为模板 c++
- int数据类型的指针指向的是什么,如果是一个类的私有数据成员,我们创建了该类的两个对象?
- 时间复杂度 当具有复合数据类型(如元组或对)时?
- 如何获取C++字符数据类型的地址
- 将复杂的非基元C++数据类型转换为 Erlang/Elixir 格式,以使用 NIF 导出方法
- 构造智能点数据类型以及普通数据类型的通用方法
- 如何使映射键具有两种不同的数据类型?
- 数据类型"struct seq<0, 1, 2>{}"含义是什么?
- 如何在不破坏现有应用程序的情况下更改 API 中 stl 容器的数据类型?
- Static_cast转换为错误的数据类型,但结果仍然正确?
- 使用 Boost.Spirit 解析具有混合数据类型的 OBJ 文件?