APUE筆記之:進程環(huán)境詳解
在main中調用exit(1)和reutrn 1是等價的。
內核啟動一個進程的唯一的方法是調用exec,用戶程序終止進程的唯一方法是顯示或者隱式的調用_exit或者EXIT。
每個進程都會有一個進程表。進程表是一個全局的指針:environ。extern char **environ可以查看這個環(huán)境表。另外,可以通過getenv和putenv來獲取修改環(huán)境表。寫個程序試一下。
linux的段:linux正文段從0X08048000單元開始,棧底則從0xC0000000開始
棧是向下生長,對向上生長。這里描述的是邏輯地址。
編譯時,gcc -static可以阻止程序使用動態(tài)庫,轉而使用靜態(tài)庫。
malloc:分配指定字節(jié)存儲區(qū),值不確定。
calloc:原型為void *calloc(size_t nobj, size_t size),分配size*nobj個字節(jié)。
realloc:更改以前存儲區(qū)的長度。原型:void *realloc(void *ptr, size_t new_size);返回值可能還是原來的地址(如果它的后面有足夠的存儲區(qū)),可能發(fā)生了更改(后面沒有足夠的存儲區(qū),需要申請一塊大的,并且把原先的內容拷貝過去)。new_size是新緩沖區(qū)的大小,不是差值。如果ptr為空,則等同于malloc,如果size為0,則等同于free。新申請的東西未初始化。
返回的地址一定是對齊的,使其可以存儲任何的對象類型。比如,有些系統(tǒng)要求double類型數(shù)據(jù)的起始地址一定是8的倍數(shù)。
putenv,setenv,unsetenv三個函數(shù)可以更改進程的環(huán)境變量。
setenv:int setenv(const char *name, const char *value, int rewrite)//rewrite:如果已存在是否覆蓋。
putenv函數(shù)直接將入?yún)⒎湃氕h(huán)境表中,而不分配存儲區(qū)。這樣,如果是棧,則會出錯。
setjmp和longjmp是全局的goto,不過盡量不要使用,隱含了很多的陷阱,易出錯。
getrlimit和setrlimit可以修改進程的資源限制。一起時用命令來修改,針對的是所有的進程,這個函數(shù)可以針對當前進程。對應的命令式ulimit。
寫測試程序驗證:
1、 程序死循環(huán),有printf,前臺啟動和后臺啟動所占用的CPU是否相同?
2、 打開文件,然后關閉文件,說是用的時間是否太大。
還好。平均在50us(0.05毫秒)
3、 打開大的文件和打開一個小的文件,占用時間是否相同?差別是否大?
打開模式和打開時間有區(qū)別(下面的代碼:打開文件,寫同樣內容):
a+:20us
w+/w:70us
r:20us
r+:20us
打開一個大文件和打開一個小文件還是有差別的。
一個8M,一個3k,同樣適用a+打開,不寫內容:
8M:37us
3k: 12us
一個8M,一個3k,同樣適用a+打開,寫內容(1K):
8M:60us
3k: 23us
在寫一個250M文件,差不多也是60us。和8M差別不大。
改用flush后,寫后flush的平均大概在9us。
4、 寫文件:寫相同內容,寫到一個空白文件和寫到一個大文件中,時間是否相同?
差不多。
5、 一個文件,打開,寫內容。在進程外刪除整個文件,再寫文件??词裁葱Ч耗芊駥懗晒?,文件會不會重新生成,是否會在關閉的時候生成,是否會返回錯誤從而知道文件不存在了,是否可以通過errno獲得這一信息。
目前沒有好的方法,寫的函數(shù)的返回值是成功的,但是文件不存在。目前我的做法是寫的時候判斷文件是否存在。大約用9us的時間。這比打開在關閉要快很多的。
6、 一個線程順序的寫多個文件和多個線程并行的寫多個文件,同樣的量,花費的時間是否相同?
7、 文件IO的自帶緩存是什么時候寫到文件的?是在調用最后的那個write函數(shù)?還是在系統(tǒng)內部?如果是前一個,則write調用返回時間是不一樣的。
欄 目:C語言
下一篇:深入Main函數(shù)中的參數(shù)argc,argv的使用詳解
本文標題:APUE筆記之:進程環(huán)境詳解
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/4530.html
您可能感興趣的文章
- 01-10內部排序之堆排序的實現(xiàn)詳解
- 01-10進程間通信之深入消息隊列的詳解
- 01-10海量數(shù)據(jù)處理系列之:用C++實現(xiàn)Bitmap算法
- 01-10如何求連續(xù)幾個數(shù)之和的最大值
- 01-10C++算法之海量數(shù)據(jù)處理方法的總結分析
- 01-10深入理解c++中char*與wchar_t*與string以及wstring之間的相互轉換
- 01-10用代碼和UML圖化解設計模式之橋接模式的深入分析
- 01-10C++代碼規(guī)范之命名規(guī)則
- 01-10C語言之free函數(shù)以及野指針介紹
- 01-10C語言小程序 如何判斷兩個日期之差


閱讀排行
本欄相關
- 04-02c語言函數(shù)調用后清空內存 c語言調用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調用函數(shù)求fibo C語言調用函數(shù)求
隨機閱讀
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實例總結
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11ajax實現(xiàn)頁面的局部加載