亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言中炫酷的文件操作實例詳解

 更新時間:2021年10月17日 10:39:13   作者:針眼_  
內(nèi)存中的數(shù)據(jù)都是暫時的,當程序結(jié)束時,它們都將丟失,為了永久性的保存大量的數(shù)據(jù),C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件操作的相關資料,需要的朋友可以參考下

什么是文件

磁盤上的文件是文件

但是在程序設計中,我們一般談的文件有兩種:程序文件和數(shù)據(jù)文件(從文件功能的角度來分類)。

程序文件

包括源程序文件(例如.c文件)目標文件(windows環(huán)境后綴為.obj)可執(zhí)行程序(windos環(huán)境后綴為exe)。

數(shù)據(jù)文件 (本文重點)

文件的內(nèi)容不一定是程序,而是程序運行時讀寫的數(shù)據(jù),比如程序運行需要從中讀取數(shù)據(jù)的文件,或者輸出內(nèi)容的文件。

文件名

文件就像人一樣,他也要有姓氏和名字來讓其他文件或者人知道這個文件是誰。

對于每一個文件要,,都有一個唯一的文件標識,以便用戶識別和引用。

文件名格式:文件路徑+文件名主干+文件后綴

例如:D:\CSDN\Test.txt

為了方便起見,我們叫文件標識為文件名

文件的打開和關閉

文件指針

我們知道,指針是指向一個地址的,整形指針指向一個整形的空間,數(shù)組指針指向一個數(shù)組的空間,那么文件指針自然就是指向文件的指針了。

每個被使用的文件都在內(nèi)存中開辟了一個相應的文件信息區(qū),用來存放文件的相關信息(如文件的名字,文件狀態(tài)及文件當前的位置等)。這些信息是保存在一個結(jié)構(gòu)體變量中的。該結(jié)構(gòu)體類型是有系統(tǒng)聲明的,取名FILE。

這是再vs的stdio頭文件下的文件信息區(qū)結(jié)構(gòu)體

struct _iobuf {
        char *_ptr;
        int   _cnt;
        char *_base;
        int   _flag;
        int   _file;
        int   _charbuf;
        int   _bufsiz;
        char *_tmpfname;
        };
typedef struct _iobuf FILE;
//不同的C編譯器的FILE類型包含的內(nèi)容不完全相同,但是大同小異。

就像學生要有學號姓名年齡這些信息一樣,文件也有他的信息,比如這個文件的地址。這些信息存放于這個結(jié)構(gòu)體中,通過typedef重命名為FILE,并且我們不需要關心一些細節(jié)(你會關心我昨天晚上吃了什么嗎)。

一般都是通過一個FILE的指針來維護這個FILE結(jié)構(gòu)的變量,這樣使用起來更加方便。

下面我們可以創(chuàng)建一個FILE*的指針變量:

FILE* pf;

pf通過該文件信息區(qū)中的信息就能夠訪問該文件。

也就是說,通過文件指針變量能夠找到與它關聯(lián)的文件。

但上面的文件指針并未指向明確的位置,他暫時是一個野指針。

所以接下來,我們來學習如何打開(創(chuàng)建)一個文件。

文件函數(shù)

文件在讀寫之前應該先打開文件,在使用結(jié)束之后應該關閉文件。

在編寫程序的時候,在打開文件的同時,都會返回一個FILE*的指針變量指向該文件,也相當于建立了指針和文件的關系。

ANSIC規(guī)定使用fopen函數(shù)來打開文件,fclose來關閉文件。

//打開文件
FILE* fopen(const char *filename,const char *mode);
//第一個參數(shù)是文件名,第二個參數(shù)是打開方式
//關閉文件
int Fclose(FILE *stream);

部分打開方式如下圖

在這里插入圖片描述

現(xiàn)在我們來練習一下打開文件

//打開文件
	FILE* pf = fopen("data.txt","r");
	//以只讀的方式打開這個文件
	//如果文件打開失敗會返回空,否則會返回指向該文件的指針
	if (pf == NULL){
		perror("fopen");
		return -1;
	}
	//讀文件
	//關閉文件
	fclose(pf);
	pf = NULL;
	return 0;

在這里插入圖片描述

但是卻打開失敗了!!

原因是,從上面的打開方式一圖我們可以看出,以"r"方式打開,需要該文件真實存在,但是我并沒有創(chuàng)建這個文件,所以打開失敗了

叮~文件創(chuàng)建成功

我們再來看執(zhí)行結(jié)果

在這里插入圖片描述

這回沒有報錯

但是,這里是將data.txt文件放在了該.c文件目錄下,在我將該文件放在別的地方,仍然打開失敗報錯。

原因是,我們這段代碼只輸入了文件名,所以他只在當前文件目錄下尋找該文件,在其他地方的文件我們就找不到了。

這里我們來看看兩個東西,一個叫相對路徑,一個叫絕對路徑

相對路徑與絕對路徑

 相對路徑

只認為是當前目錄下的文件,如上面的代碼中。

絕對路徑

帶上文件的從磁盤到目標文件的路徑

例如

D:\Program Files\data.txt

但是請注意,在編程中,\是轉(zhuǎn)義字符,所以我們需要讓\不再是轉(zhuǎn)義字符,使其代表它本身

D:\Program Files\data.txt

輸入輸出流

什么是輸入輸出流

學習過編程,一定知道printf或者cout或者System.out.println吧,

這些函數(shù)用于打印數(shù)據(jù),這就是標準的輸出流。使數(shù)據(jù)輸出或者寫入文件中,我們叫輸出流。

我們打印HELLO WORLD在屏幕上,就是一個標準輸出流

像scanf之類的,從文件輸入或者讀數(shù)據(jù)到內(nèi)存中,就是輸入流。

一些基本的輸入輸出函數(shù)如下。

在這里插入圖片描述

比如,fputc就是寫一個字符進去,fgetc就是讀一個字符。

//打開文件
	FILE* pf = fopen("data.txt","w");
	if (pf == NULL){
		perror("fopen");
		return -1;
	}
	//讀文件
	fputc('a', pf);
	fputc('b', pf);
	fputc('c', pf);
	//fputc第一個參數(shù)為輸入的字符,第二個使對應文件的指針

	//關閉文件
	fclose(pf);
	pf = NULL;
	return 0;

在這里插入圖片描述

寫入了abc三個字符。

fputc和fgetc每次讀/寫一個字符后,文件指針pf會向后移動,類似strtok函數(shù)。會記錄上一次輸入/輸出的地址。

如果不這樣,那豈不是一直在一個位置重復寫入或者讀文件了。

接下來看看fgetc讀取字符

//打開文件
	FILE* pf = fopen("data.txt","r");
	if (pf == NULL){
		perror("fopen");
		return -1;
	}
	//讀文件

	int a = fgetc(pf);
	printf("%c", a);
	a = fgetc(pf);
	printf("%c", a);
	a = fgetc(pf);
	printf("%c",a);
	//關閉文件
	fclose(pf);
	pf = NULL;
	return 0;

執(zhí)行結(jié)果

在這里插入圖片描述

這就是順序讀寫,按著順序讀入寫入。

當然,有順序讀寫,就會有隨機讀寫

從字面意思就能看到,隨機讀寫emmm。

當然,除了fgetc這類,fgets自然就是讀取一行了(只會讀/寫一行哦)

如果你用這類函數(shù)輸出在標準輸入或者標準輸入(stdout或者stdin)上,他和printf,scanf沒什么區(qū)別。

接下來,我們來看二進制的讀和寫

二進制讀寫

fwirte

在這里插入圖片描述

以二進制的形式將內(nèi)容寫入文件中

第一個參數(shù)是你要寫入數(shù)據(jù)的數(shù)據(jù)地址,第二個參數(shù)是一個類型的大?。ㄗ止?jié))。第三個參數(shù)是你要寫入幾個數(shù)據(jù),第四個則是你選定寫入的流。

struct S{
	int n;
	double d;
	char name[10];
};

int main()
{
	struct S s = { 10, 3.14, "zhangsan" };
	//打開文件
	FILE* pf = fopen("data.txt","wb");
	if (pf == NULL){
		perror("fopen");
		return -1;
	}
	//讀文件
	fwrite(&s,sizeof(s),1,pf);

	//關閉文件
	fclose(pf);
	pf = NULL;
	return 0;
}

如上代碼會將數(shù)據(jù)以二進制的形式寫入data.txt

雖然我們看不懂,但是能看到zhangsan是我們輸入的內(nèi)容

在這里插入圖片描述

fread

以二進制的形式讀

在這里插入圖片描述

和fwirte一樣,只不過buffer不是const形式了,因為我們要將數(shù)據(jù)讀入該指針指向的目標。

struct S{
	int n;
	double d;
	char name[10];
};

int main()
{
	struct S s = {0};
	//打開文件
	FILE* pf = fopen("data.txt","rb");
	if (pf == NULL){
		perror("fopen");
		return -1;
	}
	//讀文件
	fread(&s,sizeof(struct S),1,pf);
	printf("%d  %lf  %s\n",s.n,s.d,s.name);

	//關閉文件
	fclose(pf);
	pf = NULL;
	return 0;
}

在這里插入圖片描述

總結(jié)

到此這篇關于C語言中文件操作的文章就介紹到這了,更多相關C語言文件操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 關于數(shù)組做函數(shù)參數(shù)的問題集合匯總

    關于數(shù)組做函數(shù)參數(shù)的問題集合匯總

    本文是對關于數(shù)組做函數(shù)參數(shù)的問題進行了詳細的匯總,需要的朋友可以過來參考下。希望對大家有所幫助
    2013-10-10
  • C++11中delete和default的用法詳解

    C++11中delete和default的用法詳解

    這篇文章主要為大家詳細介紹了C++11中delete和default的具體用法,文中的示例代碼簡潔易懂,具有一定的學習價值,感興趣的小伙伴可以了解下
    2023-08-08
  • C語言實現(xiàn)打印楊輝三角的方法詳細(三種方法)

    C語言實現(xiàn)打印楊輝三角的方法詳細(三種方法)

    楊輝三角是中國古代數(shù)學的杰出研究成果之一,它把二項式系數(shù)圖形化,把組合數(shù)內(nèi)在的一些代數(shù)性質(zhì)直觀地從圖形中體現(xiàn)出來,是一種離散型的數(shù)與形的結(jié)合。本文將介紹三種可以實現(xiàn)打印楊輝三角的辦法,感興趣的可以試一試
    2022-01-01
  • C++ 如何用cout輸出hex,oct,dec的解決方法

    C++ 如何用cout輸出hex,oct,dec的解決方法

    本篇文章是對C++中如何用cout輸出hex,oct,dec的方法進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言中的常量詳解

    C語言中的常量詳解

    本文主要講解C語言 常量,這里整理了 C語言常量的基礎知識,并附代碼示例和示例詳細講解,希望能幫助開始學習C 語言的同學
    2021-09-09
  • C++ 仿函數(shù)使用講解

    C++ 仿函數(shù)使用講解

    這篇文章主要介紹了C++ 仿函數(shù)使用講解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • C++控制臺版掃雷游戲

    C++控制臺版掃雷游戲

    這篇文章主要為大家詳細介紹了C++控制臺版掃雷游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C++ DLL動態(tài)庫的創(chuàng)建與調(diào)用(類庫,隱式調(diào)用)

    C++ DLL動態(tài)庫的創(chuàng)建與調(diào)用(類庫,隱式調(diào)用)

    本文主要介紹了C++ DLL動態(tài)庫的創(chuàng)建與調(diào)用(類庫,隱式調(diào)用),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C++中strstr函數(shù)的實現(xiàn)方法總結(jié)

    C++中strstr函數(shù)的實現(xiàn)方法總結(jié)

    這篇文章主要介紹了C++中strstr函數(shù)的實現(xiàn)方法總結(jié)的相關資料,希望通過本文能幫助到大家,讓大家掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-10-10
  • C++并查集親戚(Relations)算法實例

    C++并查集親戚(Relations)算法實例

    這篇文章主要介紹了C++并查集親戚(Relations)算法,實例分析了并查集親戚算法的原理與實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-04-04

最新評論