訂閱
糾錯
加入自媒體

一文了解Windows系統(tǒng)中如何讀寫臨時文件

2021-07-30 09:21
道哥分享
關注

測試代碼

FILE_ATTRIBUTE_NORMAL 屬性

FILE_ATTRIBUTE_TEMPORARY | FILE_FLAG_DELETE_ON_CLOSE 屬性

在之前的一個項目中,有一些文件,在部署到設備中時是被壓縮過的。

但是在運行階段需要解壓的時候,基于文件安全性和讀寫效率的考慮,不想把解壓后的內容存儲在硬盤上,于是尋找解決方案。

首先想到的就是:臨時文件系統(tǒng)。

在 Linux 系統(tǒng)中,創(chuàng)建臨時文件系統(tǒng)很簡單,執(zhí)行如下指令即可:

mouint -t tempfs -o size=1024m tmpfs /mnt/tmp

掛載成功后,在 /mnt/tmp 這個掛載點下創(chuàng)建的所有文件都將會是臨時文件, 也就是說:當電腦關機之后,這些文件就消失了。

這樣做的好處是:不需要硬盤的 I/O 操作,讀寫速度都非?!

那么,在 Windows 系統(tǒng)中應該用什么方法來達到類似的目的呢?

有很多的第三方軟件來創(chuàng)建內存文件系統(tǒng)(RamDisk),搜索了一下,這些獨立的工具感覺有點大材小用。

在調研的過程中,發(fā)現(xiàn) Windows 中,在創(chuàng)建文件時,有 2 個非常棒的屬性,可以達到想要的目的:

FILE_ATTRIBUTE_TEMPORARY

FILE_FLAG_DELETE_ON_CLOSE

話不多說,直接上代碼測試!

測試代碼 #include

為了便于在程序的執(zhí)行過程中,觀察被操作的文件 hello.txt,我們在每次往文件寫入數(shù)據(jù)之后,休眠 1 秒鐘。

CreateFile API 參數(shù)說明:

HANDLE CreateFile(
 LPCSTR                lpFileName,
 DWORD                 dwDesiredAccess,
 DWORD                 dwShareMode,
 LPSECURITY_ATTRIBUTES lpSecurityAttributes,
 DWORD                 dwCreationDisposition,
 DWORD                 dwFlagsAndAttributes,
 HANDLE                hTemplateFile
);
FILE_ATTRIBUTE_NORMAL 屬性

官方說明:

這應該是開發(fā)過程中最常用的屬性了。

測試一下:

在寫入的過程中,可以使用編輯器來打開 hello.txt 文件。

并且每次打開時,都可以看到實時的數(shù)據(jù)。說明操作系統(tǒng)把內存緩沖區(qū)中的內容,立刻刷新到硬盤中。

FILE_ATTRIBUTE_TEMPORARY | FILE_FLAG_DELETE_ON_CLOSE 屬性

首先看一下官方對 FILE_ATTRIBUTE_TEMPORARY 的說明:

理解:系統(tǒng)盡自己最大的可能(內存容量),把寫入文件中的數(shù)據(jù),盡量保存在 RAM 中。只有在內存壓力比較大時,才會寫入硬盤。

我們再來看下一個屬性:FILE_FLAG_DELETE_ON_CLOSE,官方說明:

理解:當文件句柄被關閉的時候,硬盤中的文件會立刻被刪除。

測試記錄:

當程序往文件寫入數(shù)據(jù)的時候,可以在資源管理器中看到該文件名,但是文件大小是 0。

使用編輯器打開的時候報錯:無法打開文件,相當于應用程序獨占了該文件。

當程序執(zhí)行 CloseHandle() 之后,資源管理器中的 hello.txt 文件被自動刪除了。

在一些特殊的使用場景中,這樣的特性還是很有幫助的。

以上這個知識點的小分享,希望在某些時候給你帶來不一樣的思路!

聲明: 本文由入駐維科號的作者撰寫,觀點僅代表作者本人,不代表OFweek立場。如有侵權或其他問題,請聯(lián)系舉報。

發(fā)表評論

0條評論,0人參與

請輸入評論內容...

請輸入評論/評論長度6~500個字

您提交的評論過于頻繁,請輸入驗證碼繼續(xù)

暫無評論

暫無評論

人工智能 獵頭職位 更多
掃碼關注公眾號
OFweek人工智能網(wǎng)
獲取更多精彩內容
文章糾錯
x
*文字標題:
*糾錯內容:
聯(lián)系郵箱:
*驗 證 碼:

粵公網(wǎng)安備 44030502002758號