淺析size_t和ssize_t

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。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章