一文了解Windows系統(tǒng)中如何讀寫(xiě)臨時(shí)文件
測(cè)試代碼
FILE_ATTRIBUTE_NORMAL 屬性
FILE_ATTRIBUTE_TEMPORARY | FILE_FLAG_DELETE_ON_CLOSE 屬性
在之前的一個(gè)項(xiàng)目中,有一些文件,在部署到設(shè)備中時(shí)是被壓縮過(guò)的。
但是在運(yùn)行階段需要解壓的時(shí)候,基于文件安全性和讀寫(xiě)效率的考慮,不想把解壓后的內(nèi)容存儲(chǔ)在硬盤(pán)上,于是尋找解決方案。
首先想到的就是:臨時(shí)文件系統(tǒng)。
在 Linux 系統(tǒng)中,創(chuàng)建臨時(shí)文件系統(tǒng)很簡(jiǎn)單,執(zhí)行如下指令即可:
mouint -t tempfs -o size=1024m tmpfs /mnt/tmp
掛載成功后,在 /mnt/tmp 這個(gè)掛載點(diǎn)下創(chuàng)建的所有文件都將會(huì)是臨時(shí)文件, 也就是說(shuō):當(dāng)電腦關(guān)機(jī)之后,這些文件就消失了。
這樣做的好處是:不需要硬盤(pán)的 I/O 操作,讀寫(xiě)速度都非?!
那么,在 Windows 系統(tǒng)中應(yīng)該用什么方法來(lái)達(dá)到類(lèi)似的目的呢?
有很多的第三方軟件來(lái)創(chuàng)建內(nèi)存文件系統(tǒng)(RamDisk),搜索了一下,這些獨(dú)立的工具感覺(jué)有點(diǎn)大材小用。
在調(diào)研的過(guò)程中,發(fā)現(xiàn) Windows 中,在創(chuàng)建文件時(shí),有 2 個(gè)非常棒的屬性,可以達(dá)到想要的目的:
FILE_ATTRIBUTE_TEMPORARY
FILE_FLAG_DELETE_ON_CLOSE
話不多說(shuō),直接上代碼測(cè)試!
測(cè)試代碼 #include
為了便于在程序的執(zhí)行過(guò)程中,觀察被操作的文件 hello.txt,我們?cè)诿看瓮募䦟?xiě)入數(shù)據(jù)之后,休眠 1 秒鐘。
CreateFile API 參數(shù)說(shuō)明:
HANDLE CreateFile(
LPCSTR lpFileName,
DWORD dwDesiredAccess,
DWORD dwShareMode,
LPSECURITY_ATTRIBUTES lpSecurityAttributes,
DWORD dwCreationDisposition,
DWORD dwFlagsAndAttributes,
HANDLE hTemplateFile
);
FILE_ATTRIBUTE_NORMAL 屬性
官方說(shuō)明:
這應(yīng)該是開(kāi)發(fā)過(guò)程中最常用的屬性了。
測(cè)試一下:
在寫(xiě)入的過(guò)程中,可以使用編輯器來(lái)打開(kāi) hello.txt 文件。
并且每次打開(kāi)時(shí),都可以看到實(shí)時(shí)的數(shù)據(jù)。說(shuō)明操作系統(tǒng)把內(nèi)存緩沖區(qū)中的內(nèi)容,立刻刷新到硬盤(pán)中。
FILE_ATTRIBUTE_TEMPORARY | FILE_FLAG_DELETE_ON_CLOSE 屬性
首先看一下官方對(duì) FILE_ATTRIBUTE_TEMPORARY 的說(shuō)明:
理解:系統(tǒng)盡自己最大的可能(內(nèi)存容量),把寫(xiě)入文件中的數(shù)據(jù),盡量保存在 RAM 中。只有在內(nèi)存壓力比較大時(shí),才會(huì)寫(xiě)入硬盤(pán)。
我們?cè)賮?lái)看下一個(gè)屬性:FILE_FLAG_DELETE_ON_CLOSE,官方說(shuō)明:
理解:當(dāng)文件句柄被關(guān)閉的時(shí)候,硬盤(pán)中的文件會(huì)立刻被刪除。
測(cè)試記錄:
當(dāng)程序往文件寫(xiě)入數(shù)據(jù)的時(shí)候,可以在資源管理器中看到該文件名,但是文件大小是 0。
使用編輯器打開(kāi)的時(shí)候報(bào)錯(cuò):無(wú)法打開(kāi)文件,相當(dāng)于應(yīng)用程序獨(dú)占了該文件。
當(dāng)程序執(zhí)行 CloseHandle() 之后,資源管理器中的 hello.txt 文件被自動(dòng)刪除了。
在一些特殊的使用場(chǎng)景中,這樣的特性還是很有幫助的。
以上這個(gè)知識(shí)點(diǎn)的小分享,希望在某些時(shí)候給你帶來(lái)不一樣的思路!

發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
最新活動(dòng)更多
-
3月27日立即報(bào)名>> 【工程師系列】汽車(chē)電子技術(shù)在線大會(huì)
-
4月30日立即下載>> 【村田汽車(chē)】汽車(chē)E/E架構(gòu)革新中,新智能座艙挑戰(zhàn)的解決方案
-
5月15-17日立即預(yù)約>> 【線下巡回】2025年STM32峰會(huì)
-
即日-5.15立即報(bào)名>>> 【在線會(huì)議】安森美Hyperlux™ ID系列引領(lǐng)iToF技術(shù)革新
-
5月15日立即下載>> 【白皮書(shū)】精確和高效地表征3000V/20A功率器件應(yīng)用指南
-
5月16日立即參評(píng) >> 【評(píng)選啟動(dòng)】維科杯·OFweek 2025(第十屆)人工智能行業(yè)年度評(píng)選
推薦專(zhuān)題
- 1 UALink規(guī)范發(fā)布:挑戰(zhàn)英偉達(dá)AI統(tǒng)治的開(kāi)始
- 2 北電數(shù)智主辦酒仙橋論壇,探索AI產(chǎn)業(yè)發(fā)展新路徑
- 3 降薪、加班、裁員三重暴擊,“AI四小龍”已折戟兩家
- 4 “AI寒武紀(jì)”爆發(fā)至今,五類(lèi)新物種登上歷史舞臺(tái)
- 5 國(guó)產(chǎn)智駕迎戰(zhàn)特斯拉FSD,AI含量差幾何?
- 6 光計(jì)算迎來(lái)商業(yè)化突破,但落地仍需時(shí)間
- 7 東陽(yáng)光:2024年扭虧、一季度凈利大增,液冷疊加具身智能打開(kāi)成長(zhǎng)空間
- 8 地平線自動(dòng)駕駛方案解讀
- 9 封殺AI“照騙”,“淘寶們”終于不忍了?
- 10 優(yōu)必選:營(yíng)收大增主靠小件,虧損繼續(xù)又逢關(guān)稅,能否乘機(jī)器人東風(fēng)翻身?