size_t是標(biāo)準(zhǔn)C庫中定義的,應(yīng)為unsigned int。
數(shù)據(jù)類型"socklen_t"和int應(yīng)該具有相同的長度。否則就會破壞 BSD套接字層的填充.POSIX開始的時(shí)候用的是size_t, Linus Torvalds(他希望有更多的人,但顯然不是很多) 努力向他們解釋使用size_t是完全錯(cuò)誤的,因?yàn)樵?4位結(jié)構(gòu)中 size_t和int的長度是不一樣的,而這個(gè)參數(shù)(也就是accept函數(shù)的第三參數(shù))的長度必須和int一致,因?yàn)檫@是BSD套接字接口標(biāo)準(zhǔn).最終POSIX的那幫家伙找到了解決的辦法,那就是創(chuàng)造了一個(gè)新的類型"socklen_t".Linux Torvalds說這是由于他們發(fā)現(xiàn)了自己的錯(cuò)誤但又不好意思向大家伙兒承認(rèn),所以另外創(chuàng)造了一個(gè)新的數(shù)據(jù)類型 。
在C++中,設(shè)計(jì) size_t 就是為了適應(yīng)多個(gè)平臺的 。size_t的引入增強(qiáng)了程序在不同平臺上的可移植性。size_t是針對系統(tǒng)定制的一種數(shù)據(jù)類型,一般是整型,因?yàn)镃/C++標(biāo)準(zhǔn)只定義一最低的位數(shù),而不是必需的固定位數(shù)。而且在內(nèi)存里,對數(shù)的高位對齊存儲還是低位對齊存儲各系統(tǒng)都不一樣。為了提高代碼的可移植性,就有必要定議這樣的數(shù)據(jù)類型。一般這種類型都會定義到它具體占幾位內(nèi)存等。當(dāng)然,有些是編譯器或系統(tǒng)已經(jīng)給定義好的。經(jīng)測試發(fā)現(xiàn),在32位系統(tǒng)中size_t是4字節(jié)的,而在64位系統(tǒng)中,size_t是8字節(jié)的,這樣利用該類型可以增強(qiáng)程序的可移植性。
一個(gè)基本的無符號整數(shù)的C / C + +類型。 它是sizeof操作符返回的結(jié)果類型。 該類型的大小是選擇,因此,它可以存儲在理論上是可能的任何類型的數(shù)組的最大大小。 在32位系統(tǒng)為size_t將采取32位和64位 - 64位。 換句話說,一個(gè)指針可以被安全地放進(jìn)為size_t類型(一個(gè)例外是類的函數(shù)指針,但是這是一個(gè)特殊的情況下)。 為size_t類型通常用于循環(huán),數(shù)組索引,大小的存儲和地址運(yùn)算。 雖然為size_t可以存儲一個(gè)指針,它是更好地使用另一個(gè)unsinged整數(shù)類型uintptr_t形式,目的(它的名字反映了它的能力)。 在某些情況下,使用為size_t類型是更有效,比使用更無符號類型的程序員習(xí)慣性安全。
size_t是一個(gè)無符號整數(shù)memsize基地型的C / C + +語言的標(biāo)準(zhǔn)庫中定義的。 此類型在C頭文件stddef.h,在文件cstddef中所述的C + +。 位于頭文件stddef.h中定義的類型在全局命名空間,而cstddef地方在命名空間std為size_t類型。 由于C語言的標(biāo)準(zhǔn)頭文件stddef.h納入的兼容性的目的,在這些方案中,您可以在全局命名空間的類型的C + +程序(:為size_t,為size_t)和命名空間std(STD::為size_t)。
============================
主要是為了可移植用的
typedef unsigned long size_t;
typedef short pid_t;
在其他平臺上有可能是 typedef unsigned int/long long size_t, typedef long/int pid_t等等,,
這樣就可以直接用size_t pid_t定義變量了,
解釋以下pid_t的用法:
主要用在linux c下進(jìn)程管理中的,用它來表示進(jìn)程的id類型,即表示進(jìn)程表的索引(進(jìn)程表里是進(jìn)程id類型)