在main中調(diào)用exit(1)和reutrn 1是等價(jià)的。
內(nèi)核啟動(dòng)一個(gè)進(jìn)程的唯一的方法是調(diào)用exec,用戶程序終止進(jìn)程的唯一方法是顯示或者隱式的調(diào)用_exit或者EXIT。
每個(gè)進(jìn)程都會(huì)有一個(gè)進(jìn)程表。進(jìn)程表是一個(gè)全局的指針:environ。extern char **environ可以查看這個(gè)環(huán)境表。另外,可以通過(guò)getenv和putenv來(lái)獲取修改環(huán)境表。寫個(gè)程序試一下。
linux的段:linux正文段從0X08048000單元開始,棧底則從0xC0000000開始
棧是向下生長(zhǎng),對(duì)向上生長(zhǎng)。這里描述的是邏輯地址。
編譯時(shí),gcc -static可以阻止程序使用動(dòng)態(tài)庫(kù),轉(zhuǎn)而使用靜態(tài)庫(kù)。
malloc:分配指定字節(jié)存儲(chǔ)區(qū),值不確定。
calloc:原型為void *calloc(size_t nobj, size_t size),分配size*nobj個(gè)字節(jié)。
realloc:更改以前存儲(chǔ)區(qū)的長(zhǎng)度。原型:void *realloc(void *ptr, size_t new_size);返回值可能還是原來(lái)的地址(如果它的后面有足夠的存儲(chǔ)區(qū)),可能發(fā)生了更改(后面沒(méi)有足夠的存儲(chǔ)區(qū),需要申請(qǐng)一塊大的,并且把原先的內(nèi)容拷貝過(guò)去)。new_size是新緩沖區(qū)的大小,不是差值。如果ptr為空,則等同于malloc,如果size為0,則等同于free。新申請(qǐng)的東西未初始化。
返回的地址一定是對(duì)齊的,使其可以存儲(chǔ)任何的對(duì)象類型。比如,有些系統(tǒng)要求double類型數(shù)據(jù)的起始地址一定是8的倍數(shù)。
putenv,setenv,unsetenv三個(gè)函數(shù)可以更改進(jìn)程的環(huán)境變量。
setenv:int setenv(const char *name, const char *value, int rewrite)//rewrite:如果已存在是否覆蓋。
putenv函數(shù)直接將入?yún)⒎湃氕h(huán)境表中,而不分配存儲(chǔ)區(qū)。這樣,如果是棧,則會(huì)出錯(cuò)。
setjmp和longjmp是全局的goto,不過(guò)盡量不要使用,隱含了很多的陷阱,易出錯(cuò)。
getrlimit和setrlimit可以修改進(jìn)程的資源限制。一起時(shí)用命令來(lái)修改,針對(duì)的是所有的進(jìn)程,這個(gè)函數(shù)可以針對(duì)當(dāng)前進(jìn)程。對(duì)應(yīng)的命令式ulimit。
寫測(cè)試程序驗(yàn)證:
1、 程序死循環(huán),有printf,前臺(tái)啟動(dòng)和后臺(tái)啟動(dòng)所占用的CPU是否相同?
2、 打開文件,然后關(guān)閉文件,說(shuō)是用的時(shí)間是否太大。
還好。平均在50us(0.05毫秒)
3、 打開大的文件和打開一個(gè)小的文件,占用時(shí)間是否相同?差別是否大?
打開模式和打開時(shí)間有區(qū)別(下面的代碼:打開文件,寫同樣內(nèi)容):
a+:20us
w+/w:70us
r:20us
r+:20us
打開一個(gè)大文件和打開一個(gè)小文件還是有差別的。
一個(gè)8M,一個(gè)3k,同樣適用a+打開,不寫內(nèi)容:
8M:37us
3k: 12us
一個(gè)8M,一個(gè)3k,同樣適用a+打開,寫內(nèi)容(1K):
8M:60us
3k: 23us
在寫一個(gè)250M文件,差不多也是60us。和8M差別不大。
改用flush后,寫后flush的平均大概在9us。
4、 寫文件:寫相同內(nèi)容,寫到一個(gè)空白文件和寫到一個(gè)大文件中,時(shí)間是否相同?
差不多。
5、 一個(gè)文件,打開,寫內(nèi)容。在進(jìn)程外刪除整個(gè)文件,再寫文件。看什么效果:能否寫成功,文件會(huì)不會(huì)重新生成,是否會(huì)在關(guān)閉的時(shí)候生成,是否會(huì)返回錯(cuò)誤從而知道文件不存在了,是否可以通過(guò)errno獲得這一信息。
目前沒(méi)有好的方法,寫的函數(shù)的返回值是成功的,但是文件不存在。目前我的做法是寫的時(shí)候判斷文件是否存在。大約用9us的時(shí)間。這比打開在關(guān)閉要快很多的。
6、 一個(gè)線程順序的寫多個(gè)文件和多個(gè)線程并行的寫多個(gè)文件,同樣的量,花費(fèi)的時(shí)間是否相同?
7、 文件IO的自帶緩存是什么時(shí)候?qū)懙轿募模渴窃谡{(diào)用最后的那個(gè)write函數(shù)?還是在系統(tǒng)內(nèi)部?如果是前一個(gè),則write調(diào)用返回時(shí)間是不一樣的。
新聞熱點(diǎn)
疑難解答
圖片精選