您好,登錄后才能下訂單哦!
CentOS中怎么利用mkstemp命令操作臨時文件,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
mkstemp函數
int mkstemp(char *template);
mkstemp函數在系統中以唯一的文件名創建一個文件并打開,而且只有當前用戶才能訪問這個臨時文件,并進行讀、寫操作。mkstemp函數只有一個參數,這個參數是個以“XXXXXX”結尾的非空字符串。mkstemp函數會用隨機產生的字符串替換“XXXXXX”,保證了文件名的唯一性。 函數返回一個文件描述符,如果執行失敗返回-1。在glibc 2.0.6 以及更早的glibc庫中這個文件的訪問權限是0666,glibc 2.0.7以后的庫這個文件的訪問權限是0600。
臨時文件使用完成后應及時刪除,否則臨時文件目錄會塞滿垃圾。由于mkstemp函數創建的臨時文件不能自動刪除,所以執行完mkstemp函數后要調用unlink函數,unlink函數刪除文件的目錄入口,但臨時文件還可以通過文件描述符進行訪問,直到最后一個打開的進程關閉文件操作符,或者程序退出后臨時文件被自動徹底地刪除。
[cpp] view plaincopy在CODE上查看代碼片派生到我的代碼片 <span style="font-size:18px;">#include <stdio.h> #include <string.h> #include <unistd.h> #include <stdlib.h> int write_temp_file(char* buffer,size_t length) { int len=length; char filename_template[]="/tmp/temp_file.XXXXXX"; int fd=mkstemp(filename_template); unlink(filename_template);//Unlink the file, so it'll be removed when close printf("Template file name:%s\n",filename_template); write(fd,&len,sizeof(len)); write(fd,buffer,len); return fd; } char* read_temp_file(int fd, size_t* length) { char* buffer; lseek(fd,0,SEEK_SET); read(fd,length,sizeof(size_t)); buffer=(char*)malloc(*length); read(fd,buffer,*length); close(fd); // Temp file will be deleted return buffer; } int main(int argc, char** argv) { char buffer[]="Test template files"; int fd=write_temp_file(buffer,strlen(buffer)); int len=0; char* result=read_temp_file(fd,&len); printf("Len:%d\nContent:%s\n",len,result); free(result); return 0; }</span>
tmpfile函數
如果您使用C library I/O函數,并且并沒有另一個程序使用這個臨時文件,有個更簡潔的函數——tmpfile。tmpfile函數創建并打開一個臨時文件,并且自動執行了unlink。tmpfile函數返回一個文件描述符,如果執行失敗返回NULL。當程序執行了fclose或者退出時,資源被釋放。
另外,linux系統中還提供mktemp、 tmpnam、 和tempnam等函數,但是由于健壯性和安全性的問題,不建議使用。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。