【转载,百科】size_t,神奇的类型

来源:互联网 发布:java循环#拼接字符串 编辑:程序博客网 时间:2024/06/06 01:33

连接:http://baike.baidu.com/link?url=wbN2uq8Sd7HWsP4at2-7KiMN60FgKzPPfJATR02yII1wyW746jdKO8jf2nt0Lp_Tpr_9YoPZQrWSSi69tB_SaK

size_t
size_t 类型定义在 cstddef 头文件中,该文件是C标准库的头文件 stddef.h 的 C++ 版。它是一个与机器相关的 unsigned 类型,其大小足以保证存储内存中对象的大小。
例如:bitset 的 size 操作返回 bitset 对象中二进制位中的个数,返回值类型是size_t。
例如:在用下标访问元素时,vector 使用vector::size_type作为下标类型,而数组下标的正确类型则是 size_t。vector 使用的下标实际也是 size_t,源码是 typedef size_t size_type。
中文名 size_t 外文名 unsigned int 定义在 cstddef 头文件中 64 位系统中 long unsigned int

来源
size_t 是标准C库中定义的,应为 unsigned int,在 64 位系统中为 long unsigned int。
数据类型"socklen_t"和int应该具有相同的长度,否则就会破坏 BSD套接字层的填充。POSIX开始的时候用的是size_t, Linus Torvalds(他希望有更多的人,但显然不是很多) 努力向他们解释使用size_t是完全错误的,因为在64位结构中 size_t和int的长度是不一样的,而这个参数的长度必须和int一致,因为这是BSD套接字接口标准。最终POSIX的那帮家伙找到了解决的办法,那就是创造了一个新的类型"socklen_t"。Linus Torvalds说这是由于他们发现了自己的错误但又不好意思向大家伙儿承认,所以另外创造了一个新的数据类型。

使用
一个基本的无符号整数的C / C + +类型, 它是sizeof操作符返回的结果类型, 该类型的大小是选择。因此,它可以存储在理论上是可能的任何类型的数组的最大大小。换句话说,一个指针可以被安全地放进为size_t类型(一个例外是类的函数指针,但是这是一个特殊的情况下)。 size_t类型通常用于循环、数组索引、大小的存储和地址运算。虽然 size_t 可以存储一个指针,它的目的是更好地使用另一个 unsinged 整数类型 uintptr_t 形式。 在某些情况下,使用 size_t 类型是更为有效,比习惯性使用无符号类型的程序会更安全。size_t 是在基于无符号整数 memsize 类型的 C/C++ 的标准库中定义的。 C 语言中,此类型位于头文件 stddef.h 中,而在 C++ 中,则位于 cstddef 中。

实现方式
在 C++ 中,设计 size_t 就是为了适应多个平台的。size_t 的引入增强了程序在不同平台上的可移植性。size_t 是针对系统定制的一种数据类型,一般是整型,因为 C/C++ 标准只定义一最低的位数,而不是必需的固定位数。而且在内存里,对数的高位对齐存储还是低位对齐存储各系统都不一样。为了提高代码的可移植性,就有必要定义这样的数据类型。一般这种类型都会定义到它具体占几位内存等。当然,有些是编译器或系统已经给定义好的。经测试发现,在 32 位系统中 size_t 是 4 字节的,而在 64 位系统中,size_t 是 8 字节的,这样利用该类型可以增强程序的可移植性。

详细解释
size_t 在 C 语言中就有了。
它是一种“整型”类型,里面保存的是一个整数,就像 int, long 那样。这种整数用来记录一个大小(size)。size_t 的全称应该是 size type,就是说 “一种用来记录大小的数据类型”。
通常我们用 sizeof(XXX) 操作,这个操作所得到的结果就是 size_t 类型。
因为 size_t 类型的数据其实是保存了一个整数,所以它也可以做加减乘除,也可以转化为 int 并赋值给 int 类型的变量。
类似的还有 wchar_t, ptrdiff_t。
wchar_t 就是 wide char type,“一种用来记录一个宽字符的数据类型”。
ptrdiff_t 就是 pointer difference type,“一种用来记录两个指针之间的距离的数据类型”。
通常,size_t 和 ptrdiff_t 都是用 typedef 来实现的。你可能在某个头文件里面找到类似的语句:
typedef unsigned int size_t;
而 wchar_t 则稍有不同。在一些旧的编译器中,wchar_t 也可能是用 typedef 来实现,但是新的标准中 wchar_t 已经是 C/C++ 语言的关键字,wchar_t 类型的地位已经和 char, int 的地位等同了。
在标准 C/C++ 的语法中,只有 int float char bool 等基本的数据类型,至于 size_t,或 size_type 都是以后的编程人员为了方便记忆所定义的一些便于理解的由基本数据类型的变体类型。
例如:typedef int size_t; 定义了 size_t 为整型。

示例代码

int i;//定义一个int类型的变量isize_t size=sizeof(i);//用sizeof操作得到变量i的类型的大小//这是一个size_t类型的值//可以用来对一个size_t类型的变量做初始化i=(int)size;//size_t类型的值可以转化为int类型的值charc='a';//c保存了字符a,占一个字节wchar_twc=L'a';//wc保存了宽字符a,占两个字节//注意'a'表示字符a,L'a'表示宽字符aintarr[]={1,2,3,4,5};//定义一个数组int*p1=&arr[0];//取得数组中元素的地址,赋值给指针int*p2=&arr[3];ptrdiff_t diff=p2-p1;//指针的减法可以计算两个指针之间相隔的元素个数//所得结果是一个ptrdiff_t类型i=(int)diff;//ptrdiff_t类型的值可以转化为int类型的值
--EOF--

0 0
原创粉丝点击