AD

ssize_t与size_t 探索

事实根本:
1.size_t 不符合BSD套接字接口标准
2.size_t 在64位系统中,和int长度不一样
3.POSIX保留了size_of的错误,故1和2恒正确

4.POSIX创建了一个新的正确的类型 socklen_t

5.在32位系统上 size_t为  unsigned int
6.在64位系统上 size_t位  unsigned long

又有:

7.ssize_t是 signed size_t

故可以得出:

8.在32位系统上  ssize_t等于  signed size_t
9.因为条件5,故可以得出:
在在32位系统上  ssize_t等于 signed int

10.在64位系统上  ssize_t等于  signed size_t
11.因为条件6,故可以得出:
在64位系统上  ssize_t等于  signed long

 

其他参考阅读:

ssize_t是signed size_t,而size_t是标准C库中定义的,应为unsigned int。
socket_t:

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

为了增强程序的可移植性,便有了size_t,它是为了方便系统之间的移植而定义的,不同的系统上,定义size_t可能不一样。

在32位系统上 定义为 unsigned int 在32位系统上是32位无符号整形

在64位系统上 定义为 unsigned long 在64位系统上是64位无符号整形

一些区别:

size_t一般用来表示一种计数,比如有多少东西被拷贝等。例如:sizeof操作符的结果类型是size_t。该类型保证能容纳实现所建立的最大对象的字节大小。 它的意义大致是“适于计量内存中可容纳的数据项目个数的无符号整数类型”。 所以,它在数组下标和内存管理函数之类的地方广泛使用。

而ssize_t:这个数据类型用来表示可以被执行读写操作的数据块的大小.它和size_t类似,但必需是signed.意即:它表示的是sign size_t类型的。

评论

此博客中的热门博文

简单粗暴导出小米便签

我——终于一个人了

多种方法绕过POWERSHELL的执行策略