看板 C_and_CPP 關於我們 聯絡資訊
請問有需要在離開 process 時, close fd 嗎? 我想這大家一定都會說是。 開檔時, 核心分配一塊 file structure,fd 就是每個 process 內的 fd table 的索引,fd 就會指向某個文件的 inode。 當每一次指向(引用),就會引用+1 當完全沒process引用了此文件,記憶體就會被銷毀? 想請問 1 核心分配的 file structure 是 heap memory 嗎? 2 請問 process exit 時,引用會消失嗎? 如果引用會消失,那有必要還要 close(fd)? 感謝 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 59.115.72.6 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1627304107.A.BE9.html
Schottky: 看平台而定。如果你在寫冷氣機或遙控直升機的程式, 07/27 02:20
Schottky: 有可能不會自動幫你 close fd 07/27 02:20
Lipraxde: OS 在 process 結束回收資源的時候會幫你關吧,就像亂 07/27 08:20
Lipraxde: 丟垃圾媽媽會幫忙收的感覺? 07/27 08:20
CGS0: 保持好的習慣 ,會讓你寫大程式時 ,減少很多除錯的時間 07/27 13:18
cuteSquirrel: 最好養成有開有關的習慣 07/27 13:45
Qbsuran: 那你覺得為什麼不用關 07/27 15:19
d630200x: 養成習慣吧 07/28 00:04
sunneo: 要關啊 假設今天把fd fileop 真正mapping到自動車跟車庫 07/28 00:45
sunneo: 車子跑一跑,車庫沒關,那就有差了 07/28 00:45
b0920075: trace 了一下 linux 5.10.1 開啟 regular file 會在 fs 07/28 01:46
b0920075: /file_table.c 的 __alloc_file 用 kmem_cache_zalloc 07/28 01:46
b0920075: 分配 object , kernel 的動態分配記憶體不確定有沒有 07/28 01:46
b0920075: 稱為 heap 的慣例(usermode 下看 process memory maps 07/28 01:46
b0920075: 是直接就寫 heap , kernel 印象沒看過這種說法?) 07/28 01:46
b0920075: exit syscall 就會call filp_close 關檔案引用減一,以 07/28 01:54
b0920075: 上是 5.10.1 版本的 kernel 07/28 01:54
b0920075: 如果是linux 然後 process 又是正常關掉 linux 是會幫 07/28 01:56
b0920075: 你收好,但其他 os 就不好說了吧 07/28 01:56
isaacting: 有些東西沒有跑os的,不關會造成嚴重的錯誤 07/28 12:02
isaacting: 我曾經在mcu上對sd卡讀寫,有api類似開關檔,寫了之後 07/28 12:03
isaacting: 沒有下關的指令,會讓sd card讀寫造成錯誤 07/28 12:03
Killercat: 通常關一關比較好 07/28 16:26
pponywong: 同上面講的 fd 不見得是檔案 char kernel driver 都有 07/28 19:42
pponywong: 可能用fd來操作 kernel driver不一定保證幫你處理 07/28 19:43
pponywong: resource release的操作 我就遇過系統中直接發signal 07/28 19:44
pponywong: 去砍掉程式 造成kernel panic的 07/28 19:44
alex70266: 想不到什麼理由不關啦,更何況這是確保安全的習慣 07/28 23:11
alex70266: 難道有了免治馬桶以後就不用買衛生紙嗎XD 07/28 23:12
askacis: 不關fd, 則 process 會佔用 一個 fd號碼,系統跑久之後你 07/28 23:59
askacis: 就會發現為什麼沒辦法開檔了,因為系統的 fd都用光光了 07/28 23:59
askacis: 很多系統靈異現象都是這樣來的,記得用 lsof 查誰佔住了 07/29 00:00
askacis: 一堆 fd 07/29 00:00
b0920075: 如果是 process 一直跑但是不關 fd 達到給 process 的 07/29 01:51
b0920075: fd 上限後開下一個就會失敗,但 fd 只跟 process 有關 07/29 01:51
b0920075: 吧,跟系統上跑的其他 process 應該是獨立不相干的? 07/29 01:51
jacky1989: 建議保持好習慣,有fopen 就有fclose 07/30 00:37
ibmibmibm: 如果你在寫飛彈的程式,那可能發射兩分鐘後就有終極的 08/10 09:46
ibmibmibm: 全系統資源回收,那就不用關了,不然還是都記得關吧 08/10 09:46
youtuuube000: 問題是process很可能會長期跑啊..一直開著到時fd爆 08/12 14:43
youtuuube000: 掉怎辦 08/12 14:43
ArdenCho: 關一關吧,養成一個好習慣 09/28 22:49