linux 格式化輸出輸入函數

來源:互聯網
上載者:User

fread函數和fwrite函數
1.函數功能
  用來讀寫一個資料區塊。
2.一般調用形式
  fread(buffer,size,count,fp);
  fwrite(buffer,size,count,fp);
3.說明
  (1)buffer:是一個指標,對fread來說,它是讀入資料的存放地址。對fwrite來說,是要輸出資料的地址。
  (2)size:要讀寫的位元組數;
  (3)count:要進行讀寫多少個size位元組的資料項目;
  (4)fp:檔案型指標。
4.舉例
  例1  從鍵盤輸入4個學生的有關資料,然後把它們轉存到磁碟檔案上去。
   (1)演算法分析;
   (2)程式參見:li13-3.c
例2  從例1產生的檔案中讀入有關資料,然後把它們在螢幕上輸出。
   (1)演算法分析;
   (2)程式參見:li13-4.c
※ fwrite,fread,fopen讀寫結構體。 ※
用fwrite,fread來讀寫檔案,總結都在代碼注釋之中,注意讀寫的時候用了二進位模式,用文字模式會出現問題。
#i nclude "iostream"
#i nclude "iomanip"
using namespace std;
typedef struct tagTEST
{
char Name[40];
int  Size;
int  Array[200];
}TEST,*PTEST;
void OutPut(TEST *S)
{
coutNameSizeArray;
        if(++i%8==0)
   cout
//以下用來讀檔案 。
    cout
資料區塊讀寫函數fread和fwrite
C語言還提供了用於整塊資料的讀寫函數。 可用來讀寫一組資料,如一個數組元素,一個結構變數的值等。讀資料區塊函數調用的一般形式為: fread(buffer,size,count,fp); 寫資料區塊函數調用的一般形式為: fwrite(buffer,size,count,fp); 其中buffer是一個指標,在fread函數中,它表示存放輸入資料的首地址。在fwrite函數中,它表示存放輸出資料的首地址。 size 表示資料區塊的位元組數。count 表示要讀寫的資料區塊塊數。fp 表示檔案指標。
例如:
fread(fa,4,5,fp); 其意義是從fp所指的檔案中,每次讀4個位元組(一個實數)送入實數組fa中,連續讀5次,即讀5個實數到fa中。
[例10.6]從鍵盤輸入兩個學生資料,寫入一個檔案中, 再讀出這兩個學生的資料顯示在螢幕上。
#include
struct stu
{
char name[10];
int num;
int age;
char addr[15];
}boya[2],boyb[2],*pp,*qq;
main()
{
FILE *fp;
char ch;
int i;
pp=boya;
qq=boyb;
if((fp=fopen("stu_list","wb+"))==NULL)
{
printf("Cannot open file strike any key exit!");
getch();
exit(1);
}
printf("\ninput data\n");
for(i=0;iname,&pp->num,&pp->age,pp->addr);
pp=boya;
fwrite(pp,sizeof(struct stu),2,fp);
rewind(fp);
fread(qq,sizeof(struct stu),2,fp);
printf("\n\nname\tnumber age addr\n");
for(i=0;iname,qq->num,qq->age,qq->addr);
fclose(fp);
}
本常式序定義了一個結構stu,說明了兩個結構數組boya和 boyb以及兩個結構指標變數pp和qq。pp指向boya,qq指向boyb。程式第16行以讀寫方式開啟二進位檔案“stu_list”,輸入二個學生資料之後,寫入該檔案中, 然後把檔案內部位置指標移到檔案首,讀出兩塊學生資料後,在螢幕上顯示。
格式化讀寫函數fscanf和fprintf
fscanf函數,fprintf函數與前面使用的scanf和printf 函數的功能相似,都是格式化讀寫函數。 兩者的區別在於 fscanf 函數和fprintf函數的讀寫對象不是鍵盤和顯示器,而是磁碟檔案。這兩個函數的調用格式為: fscanf(檔案指標,格式字串,輸入表列); fprintf(檔案指標,格式字串,輸出表列); 例如:
fscanf(fp,"%d%s",&i,s);
fprintf(fp,"%d%c",j,ch);
用fscanf和fprintf函數也可以完成例10.6的問題。修改後的程式如例10.7所示。
[例10.7]
#include
struct stu
{
char name[10];
int num;
int age;
char addr[15];
}boya[2],boyb[2],*pp,*qq;
main()
{
FILE *fp;
char ch;
int i;
pp=boya;
qq=boyb;
if((fp=fopen("stu_list","wb+"))==NULL)
{
printf("Cannot open file strike any key exit!");
getch();
exit(1);
}
printf("\ninput data\n");
for(i=0;iname,&pp->num,&pp->age,pp->addr);
pp=boya;
for(i=0;iname,pp->num,pp->age,pp->
addr);
rewind(fp);
for(i=0;iname,&qq->num,&qq->age,qq->addr);
printf("\n\nname\tnumber age addr\n");
qq=boyb;
for(i=0;iname,qq->num, qq->age,
qq->addr);
fclose(fp);
}
與例10.6相比,本程式中fscanf和fprintf函數每次只能讀寫一個結構數組元素,因此採用了迴圈語句來讀寫全部數組元素。 還要注意指標變數pp,qq由於迴圈改變了它們的值,因此在程式的25和32行分別對它們重新賦予了數組的首地址。
檔案的隨機讀寫
前面介紹的對檔案的讀寫方式都是順序讀寫, 即讀寫檔案只能從頭開始,順序讀寫各個資料。 但在實際問題中常要求唯讀寫檔案中某一指定的部分。 為瞭解決這個問題可移動檔案內部的位置指標到需要讀寫的位置,再進行讀寫,這種讀寫稱為隨機讀寫。 實現隨機讀寫的關鍵是要按要求移動位置指標,這稱為檔案的定位。檔案定位移動檔案內部位置指標的函數主要有兩個, 即 rewind 函數和fseek函數。
rewind函數前面已多次使用過,其調用形式為: rewind(檔案指標); 它的功能是把檔案內部的位置指標移到檔案首。 下面主要介紹
fseek函數。
fseek函數用來移動檔案內部位置指標,其調用形式為: fseek(檔案指標,位移量,起始點); 其中:“檔案指標”指向被移動的檔案。 “位移量”表示移動的位元組數,要求位移量是long型資料,以便在檔案長度大於64KB 時不會出錯。當用常量表示位移量時,要求加尾碼“L”。“起始點”表示從何處開始計算位移量,規定的起始點有三種:檔案首,當前位置和檔案尾。
其表示方法如表10.2。
起始點 表示符號 數字表示
──────────────────────────
檔案首 SEEK—SET 0
當前位置 SEEK—CUR 1
檔案末尾 SEEK—END 2
例如:
fseek(fp,100L,0);其意義是把位置指標移到離檔案首100個位元組處。還要說明的是fseek函數一般用於二進位檔案。在文字檔中由於要進行轉換,故往往計算的位置會出現錯誤。檔案的隨機讀寫在移動位置指標之後, 即可用前面介紹的任一種讀寫函數進行讀寫。由於一般是讀寫一個資料據塊,因此常用fread和fwrite函數。下面用例題來說明檔案的隨機讀寫。
[例10.8]在學生檔案stu list中讀出第二個學生的資料。
#include
struct stu
{
char name[10];
int num;
int age;
char addr[15];
}boy,*qq;
main()
{
FILE *fp;
char ch;
int i=1;
qq=&boy;
if((fp=fopen("stu_list","rb"))==NULL)
{
printf("Cannot open file strike any key exit!");
getch();
exit(1);
}
rewind(fp);
fseek(fp,i*sizeof(struct stu),0);
fread(qq,sizeof(struct stu),1,fp);
printf("\n\nname\tnumber age addr\n");
printf("%s\t%5d %7d %s\n",qq->name,qq->num,qq->age,
qq->addr);
}
檔案stu_list已由例10.6的程式建立,本程式用隨機讀出的方法讀出第二個學生的資料。程式中定義boy為stu類型變數,qq為指向boy的指標。以讀二進位檔案方式開啟檔案,程式第22行移動檔案位置指標。其中的i值為1,表示從檔案頭開始,移動一個stu類型的長度, 然後再讀出的資料即為第二個學生的資料。
檔案檢測函數
C語言中常用的檔案檢測函數有以下幾個。
一、檔案結束檢測函數feof函數調用格式: feof(檔案指標);
功能:判斷檔案是否處於檔案結束位置,如檔案結束,則傳回值為1,否則為0。
二、讀寫檔案出錯檢測函數ferror函數調用格式: ferror(檔案指標);
功能:檢查檔案在用各種輸入輸出函數進行讀寫時是否出錯。 如ferror傳回值為0表示未出錯,否則表示有錯。
三、檔案出錯標誌和檔案結束標誌置0函數clearerr函數調用格式: clearerr(檔案指標);
功能:本函數用於清除出錯標誌和檔案結束標誌,使它們為0值。
C庫檔案
C系統提供了豐富的系統檔案,稱為庫檔案,C的庫檔案分為兩類,一類是副檔名為".h"的檔案,稱為標頭檔, 在前面的包含命令中我們已多次使用過。在".h"檔案中包含了常量定義、 類型定義、宏定義、函數原型以及各種編譯選擇設定等資訊。另一類是函數庫,包括了各種函數的目標代碼,供使用者在程式中調用。 通常在程式中調用一個庫函數時,要在調用之前包含該函數原型所在的".h" 檔案。
在附錄中給出了全部庫函數。
ALLOC.H 說明記憶體管理函數(分配、釋放等)。
ASSERT.H 定義 assert調試宏。
BIOS.H 說明調用IBM—PC ROM BIOS子程式的各個函數。
CONIO.H 說明調用DOS控制台I/O子程式的各個函數。
CTYPE.H 包含有關字元分類及轉換的名類資訊(如 isalpha和toascii等)。
DIR.H 包含有關目錄和路徑的結構、宏定義和函數。
DOS.H 定義和說明MSDOS和8086調用的一些常量和函數。
ERRON.H 定義錯誤碼的助記符。
FCNTL.H 定義在與open庫子程式串連時的符號常量。
FLOAT.H 包含有關浮點運算的一些參數和函數。
GRAPHICS.H 說明有關圖形功能的各個函數,圖形錯誤碼的常量定義,正對不同驅動程式的各種顏色值,及函數用到的一些特殊結構。
IO.H 包含低級I/O子程式的結構和說明。
LIMIT.H 包含各環境參數、編譯時間限制、數的範圍等資訊。
MATH.H 說明數學運算函數,還定了 HUGE VAL 宏, 說明了matherr和matherr子程式用到的特殊結構。
MEM.H 說明一些記憶體操作函數(其中大多數也在STRING.H 中說明)。
PROCESS.H 說明進程管理的各個函數,spawn…和EXEC …函數的結構說明。
SETJMP.H 定義longjmp和setjmp函數用到的jmp buf類型, 說明這兩個函數。
SHARE.H 定義檔案分享權限設定函數的參數。
SIGNAL.H 定義SIG[ZZ(Z] [ZZ)]IGN和SIG[ZZ(Z] [ZZ)]DFL常量,說明rajse和signal兩個函數。
STDARG.H 定義讀函數參數表的宏。(如vprintf,vscarf函數)。
STDDEF.H 定義一些公用資料類型和宏。
STDIO.H 定義Kernighan和Ritchie在Unix System V 中定義的標準和擴充的類型和宏。還定義標準I/O 預定義流:stdin,stdout和stderr,說明 I/O流子程式。
STDLIB.H 說明一些常用的子程式:轉換子程式、搜尋/ 排序子程式等。
STRING.H 說明一些串操作和記憶體操作函數。
SYS\STAT.H 定義在開啟和建立檔案時用到的一些符號常量。
SYS\TYPES.H 說明ftime函數和timeb結構。
SYS\TIME.H 定義時間的類型time[ZZ(Z] [ZZ)]t。
TIME.H 定義時間轉換子程式asctime、localtime和gmtime的結構,ctime、 difftime、 gmtime、 localtime和stime用到的類型,並提供這些函數的原型。
VALUE.H 定義一些重要常量, 包括依賴於機器硬體的和為與Unix System V相相容而說明的一些常量,包括浮點和雙精確度值的範圍。
本文來自CSDN部落格,轉載請標明出處:
http://blog.csdn.net/zheng80037/archive/2007/05/23/1622273.aspx

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.