size_t
size_t是一些C/C++標準在stddef.h中定義的。這個類型足以用來表示對象的大小。
size_t的真實類型與操作系統有關,在32位架構中被普遍定義爲:
typedef unsigned int size_t;
而在64位架構中被定義爲:
typedef unsigned long size_t;
ssize_t
ssize_t是有符號整型,在32位機器上等同與int,在64位機器上等同與long int,有沒有注意到,它和long數據類型有啥區別?其實就是一樣的。
size_t 就是無符號型的ssize_t
不同的編譯器或系統可能會有區別,主要是因爲在32位機器上int和long是一樣的。
在32位架構中被普遍定義爲:
typedef int size_t;
而在64位架構中被定義爲:
typedef long size_t;
-----------------------------------size_t和ssize_t----------------------------------------------
爲了增強程序的可移植性,便有了size_t,它是爲了方便系統之間的移植而定義的,不同的系統上,定義size_t可能不一樣。
在32位系統上 定義爲 unsigned int 也就是說在32位系統上是32位無符號整形。在64位系統上定義爲 unsigned long 也就是說在64位系統上是64位無符號整形。size_t一般用來表示一種計數,比如有多少東西被拷貝等。例如:sizeof操作符的結果類型是size_t,該類型保證能容納實現所建立的最大對象的字節大小。 它的意義大致是“適於計量內存中可容納的數據項目個數的無符號整數類型”。所以,它在數組下標和內存管理函數之類的地方廣泛使用。而ssize_t這個數據類型用來表示可以被執行讀寫操作的數據塊的大小.它和size_t類似,但必需是signed.
C語言中size_t的陷阱
類似這樣的程序:
#include <stdio.h>
#include <string.h>
int main()
{
int i = -1;
if(i > strlen("Demon"))
printf("Hello World");
else
printf("Hello Demon");
return 0;
}
輸出的竟然是Hello World!-1 > 5?!
仔細想想,原來問題出在strlen上,strlen返回的類型是size_t,size_t的定義爲:
typedef unsigned int size_t;
即無符號的整型,而i的類型是int,即有符號的整型。當有符號整型和無符號整型進行運算時,有符號整型會先自動轉化成無符號。-1轉化成無符號數爲4294967295,遠遠大於5。