Linux 標準IO的fopen和fclose

getchar(),putchar() ‐‐‐‐ 一個字符
gets(buf),puts(buf) ‐‐‐‐ 一串字符
scanf(),printf() ‐‐‐‐ 一個字符,一串字符都可以

fopen函數的形式

FILE * fopen(constchar *path , cost char *mode)

/*
* @description : 打開一個文件
* @param ‐ path : 指定文件路徑 , 如: "./test.txt"
* @param ‐ mode :指定文件的打開方式,如下圖:

* @return :fopen:?成功,返回指向該文件的文件指針; 若失敗,返回 NULL

*/
mode有以下值:
r :只讀方式打開,文件必須存在
r+ :可讀寫,文件必須存在
rb+ :打開二進制文件,可以讀寫
rt+: 打開文本文件,可讀寫
w: 只寫,文件存在則文件長度清 0 ,文件不存在則建立該文件
w+: 可讀寫,文件存在則文件長度清 0 ,文件不存在則建立該文件
a: 附加方式打開只寫,不存在建立該文件,存在寫入的數據加到文件尾, EOF 符保留
a+ :附加方式打開可讀寫,不存在建立該文件,存在寫入的數據加到文件尾, EOF 符不保留
wb :打開二進制文件,只寫 wb+: 打開或建立二進制文件,可讀寫
wt+: 打開或建立文本文件,可讀寫
at+: 打開文本文件,可讀寫,寫的數據加在文本末尾 ab+: 打開二進制文件,可讀寫,寫的數據加在文件末尾

fclose函數的形式

函數原型:int fclose(FILE*stream)

關閉一個文件流,使用 fclose 就可以把緩沖區內最后剩余的數據輸出到磁盤文件中,并釋放文件指針和有關的緩沖區

/*
* @description : 關閉一個已打開的流
* @param ‐ stream : 文件指針(流)

* @return : fclose:成功,返回0; 若失敗,返回EOF

*/
#include<stdio.h>
int main()
{
FILE *fp = NULL;/*create a null file創建一個空的指針文件*/
int nRet = 0 ;
fp =fopen("mm","w");/*fp mode w,create*打開指針文件mm,模式為w 可寫,沒有文件則創建文件/
if (fp == NULL)/*NUll open failed!如果創建不成功,則fp=NULL*/
{
printf("open failed!\n");
return -1;}
printf("open success!\n");/*成功打開則輸出打開成功*/
nRet = fclose(fp);
if(nRet)/*close success,others failed!*如果關閉成功則返回0,如果返回其他,則關閉不成功*/
{printf("close failed!\n");
return -2;}
printf("close success!\n");/*成功則返回關閉成功*/
return 0;}
~    

lpych@lpych-virtual-machine:~$ gcc demo2.c -o demo

編譯demo2.c 編譯完后的文件為demo

lpych@lpych-virtual-machine:~$ ./demo
運行demo

提示:open success!
close success!

說明打開和關閉文件 mm成功!

lpych@lpych-virtual-machine:~$ ls -l
查看文件的權限,mm文件

因為之前mm文件有創建過,模式為0755,可讀可寫可執行,可讀可執行,可讀可執行

因此 lpych用戶,可讀可寫可執行,組用戶,可讀可執行,其他用戶,可讀可執行

之前有操作生成過mm,將新文件命名ll

#include<stdio.h>
int main()
{
FILE *fp = NULL;
int nRet = 0 ;
fp =fopen("ll","w");
if (fp == NULL)
{
printf("open failed!\n");
return -1;}
printf("open success!\n");
nRet = fclose(fp);
if(nRet)
{printf("close failed!\n");
return -2;}
printf("close success!\n");
return 0;}
~  

lpych用戶,可讀可寫,組用戶,可讀,其他用戶,可讀?

與w模式相對應

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/35217.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/35217.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/35217.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

進階篇07——InnoDB引擎介紹

概覽 邏輯存儲結構 架構 當執行增刪改查操作時&#xff0c;操作的是緩沖區的數據&#xff0c;如果緩沖區里沒有要操作的數據&#xff0c;就會從磁盤中讀取數據加載到緩沖區中&#xff1b;緩沖區的數據會以一定的頻率通過后臺線程刷新到磁盤中永久存儲。 內存結構 磁盤結構 后…

數據結構(Java):順序表集合類ArrayList

1、線性表 線性表&#xff0c;在邏輯結構上是連續的&#xff08;可理解為連續的一條直線&#xff0c;一對一的關系&#xff09;&#xff0c;而在物理結構上不一定連續&#xff0c;通常以數組和鏈式結構進行存儲。 線性表是一種在實際中廣泛使用的數據結構&#xff0c;常見的線…

Vue介紹與入門(一篇入門)

Vue.js 是一個流行的 JavaScript 框架&#xff0c;專門用于構建用戶界面和單頁面應用程序。它簡單易學&#xff0c;但功能強大&#xff0c;能夠幫助開發者快速構建交互性強的 Web 應用。 本教程旨在幫助那些剛開始學習 Vue.js 的開發者快速入門&#xff0c;并掌握一些基礎知識…

【UE5.1 角色練習】12-坐騎——Part2(讓角色騎上坐騎)

目錄 前言 效果 步驟 一、坐騎的父類 二、將角色附加到坐騎 三、添加坐姿 四、騎上坐騎 五、從坐騎上下來 前言 在上一篇&#xff08;【UE5.1 角色練習】11-坐騎——Part1&#xff08;控制大象移動&#xff09;&#xff09;基礎上繼續實現角色騎上坐騎的功能。 效果 …

語言的數據結構:樹與二叉樹(二叉樹篇)

語言的數據結構&#xff1a;樹與二叉樹&#xff08;二叉樹篇&#xff09; 前言概念特別的二叉樹滿二叉樹完全二叉樹 存儲結構順序存儲鏈式存儲 查找方式 前言 上文說到了樹&#xff0c;有人認為二叉樹是樹的每一個分支都有兩個子節點。其實這也對。但二叉樹在此基礎上還做了限…

RS422串口通信協議介紹和基礎代碼實現

**RS-422串口協議介紹**RS-422是一種工業標準的通信接口&#xff0c;其全稱是“平衡電壓數字接口電路的電氣特性”。它是在RS-232的基礎上發展而來&#xff0c;旨在解決RS-232通信距離短和速率低的缺點。以下是對RS-422串口協議的詳細介紹&#xff1a;傳輸速率與距離&#xff1…

MyCAT 2 簡單入門

MyCAT 2 基礎 什么是 MyCAT 2&#xff1f; MyCAT 2 是一款開源的數據庫中間件&#xff0c;它主要用于解決數據庫的分庫分表、讀寫分離等問題。MyCAT 2 基于 MyCAT 1 的架構進行優化和重構&#xff0c;具有更高的性能和穩定性&#xff0c;支持多種數據庫類型&#xff0c;包括 …

【QCustomPlot實戰系列】QCPGraph區域高亮

使用QCPDataSelection來設置選中的區域&#xff0c;并將QCPGraph的可選擇區域設置成QCP::stMultipleDataRanges void AreaPieces::initCustomPlot(QCustomPlot *parentPlot) {QVector<double> x {0, 1, 2, 3, 4, 5, 6, 7, 8};QVector<double> y {200, 560, 750…

《mysql篇》--mysql常用命令

數據庫操作 顯示當前數據庫 show databases;(database 后面要加s) 這行命令用來顯示當前有多少個數據庫 //mysql中有自帶的四個庫 創建數據庫 create database 數據庫名(name); 創建一個數據庫 create dabase if not exists <數據庫名(name)>; //如果系統有與當前創建…

前端vite+vue3——利用環境變量和路由區分h5、pc模塊打包(從0到1)

?前言 大家好&#xff0c;我是yma16&#xff0c;本文分享 前端vitevue3——利用環境變量和路由對前端區分h5和pc模塊打包&#xff08;從0到1&#xff09;。 背景&#xff1a; 前端本地開發pc和h5的項目&#xff0c;發布時需要區分開h5和pc的頁面 vite Vite 通過在一開始將應…

圖片怎么加水印?快來試試這6個圖片加水印方法(2024年新)

圖片怎么加水印&#xff1f;作為打工人在日常的工作生活中總會遇到各種各樣的工作難題&#xff0c;相信從事電商或者是設計等工作的小伙伴們&#xff0c;遇到最多的問題應該就是給圖片添加水印了。為什么要給圖片加水印&#xff1f;其實給圖片加水印最主要的目的是保護我們的圖…

刷題——二叉樹的中序遍歷

雙指針法 void midorder(vector<int>&res, TreeNode* root){if(root NULL) return;midorder(res, root->left);res.push_back(root->val);midorder(res, root->right);}vector<int> inorderTraversal(TreeNode* root) {// write code herevector<…

代碼隨想錄算法訓練營第四十九天|LeetCode300 最長遞增子序列、LeetCode674 最長連續遞增序列、LeetCode718 最長重復子數組

題1&#xff1a; 指路&#xff1a;300. 最長遞增子序列 - 力扣&#xff08;LeetCode&#xff09; 思路與代碼&#xff1a; 求最長遞增子序列&#xff0c;那么就定義一個數組dp[i]&#xff0c;含義為最長遞增子序列。這里有一個小問題&#xff0c;這里的序列的范圍為何。如果…

一文入門Makefile

今天我們來玩玩Makefile。 這邊是借鑒的陳皓老師的《跟我一起寫 Makefile》 pdf下載鏈接如下。 鏈接&#xff1a;https://pan.baidu.com/s/1woRq2nEkgzLv1o5uE0FZHg?pwdmhrh 提取碼&#xff1a;mhrh 我們之前已經算是入門了gcc&#xff0c;那我們的下一站就是Makefile&…

http和https請求總結

http請求是不安全的請求的端口是80&#xff0c;https請求是安全的請求的端口是443 但是請求安全也不是絕對的。 要想先了解https就的先說幾個概念 1、證書 2、加密算法 openssl TLS/SSL 3、協議x509協議 http傳輸數據都是明文&#xff0c;在數據傳輸的過程會經過很長的鏈路…

C#面: 能夠將非靜態的方法覆寫成靜態方法嗎?

在C#中&#xff0c;不能將非靜態方法覆寫成靜態方法。這是因為靜態方法是屬于類的&#xff0c;而非靜態方法是屬于類的實例的。覆寫&#xff08;重寫&#xff09;是指在派生類中重新實現基類中的虛方法或抽象方法&#xff0c;以改變其行為。而靜態方法是無法被派生類所繼承的&a…

嵌入式學習(Day 51:ARM指令/匯編與c語言函數相互調用)

1.Supervisor模式與SVC模式 Supervisor模式是ARM處理器的一個特權工作模式&#xff0c;允許執行特權指令和訪問特權資源。SVC模式&#xff08;Supervisor Call&#xff09;是與Supervisor模式相關的一個功能或指令&#xff0c;用于從用戶模式切換到Supervisor模式&#xff0c;…

1、Redis系列-Redis高性能原理詳解

Redis高性能原理詳解 Redis是一款高性能的內存數據庫&#xff0c;廣泛應用于需要快速讀寫訪問的數據密集型應用中。它的高性能得益于多方面的設計和優化。以下是Redis高性能實現的詳細解釋&#xff1a; 1. 單線程架構 Redis采用單線程架構來處理客戶端請求&#xff0c;這與傳…

服務器流量收發測試-續篇

文章目錄 一、概述二、普通java工程1&#xff0c;pom文件2&#xff0c; 定時任務3&#xff0c;打包4&#xff0c;jar運行 三、打包docker鏡像1&#xff0c;鏡像打包配置docker環境&#xff1a;2&#xff0c;連接遠程鏡像倉庫 四、部署運行1. 容器運行2. 單容器多次運行jar3. 容…

大模型應用研發基礎環境配置(Miniconda、Python、Jupyter Lab、Ollama等)

老牛同學之前使用的MacBook Pro電腦配置有點舊&#xff08;2015 年生產&#xff09;&#xff0c;跑大模型感覺有點吃力&#xff0c;操作起來有點卡頓&#xff0c;因此不得已撿起了塵封了快兩年的MateBook Pro電腦&#xff08;老牛同學其實不太喜歡用 Windows 電腦做研發工作&am…