程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> C語言實現二進制文件讀寫詳解

C語言實現二進制文件讀寫詳解

編輯:關於C語言

先介紹函數,我們一共要用到三個函數,fopen,fread,fwrite。二進制讀寫的順序是用fopen以二進制方式打開讀寫文件,然後使用fread和fwrite兩個函數將數據寫入二進制文件中。下面我們看看一個拷貝程序的源碼:

Copy.c:

#include <stdio.h>

#include <stdlib.h>
    
#define MAXLEN 1024
    
int main(int argc, char *argv[])
    
{
    
    if( argc < 3 )
    
    {
    
        printf("usage: %s %s/n", argv[0], "infile outfile");
    
        exit(1);
    
    }

    FILE * outfile, *infile;
    
    outfile = fopen(argv[2], "wb" );
    
    infile = fopen(argv[1], "rb");
    
    unsigned char buf[MAXLEN];
    
    if( outfile == NULL || infile == NULL )
    
    {
    
        printf("%s, %s",argv[1],"not exit/n");
    
        exit(1);
    
    }   
    
       
    
    int rc;
    
    while( (rc = fread(buf,sizeof(unsigned char), MAXLEN,infile)) != 0 )
    
    {
    
        fwrite( buf, sizeof( unsigned char ), rc, outfile );
    
}
    
fclose(infile);
    
fclose(outfile);
    
system("PAUSE");
    
return 0;
}

現在來講講這個程序,這個程序的作用就是將文件1的內容直接拷貝到文件2中,注意fread的返回值,這個值需要在fwrite的時候將會用到。

後面是關於fopen,fread,fwrite三個函數的詳細說明。

fopen(打開文件)

相關函數

open,fclose

表頭文件 #include<stdio.h>

定義函數 FILE * fopen(const char * path,const char * mode);

函數說明

參數path字符串包含欲打開的文件路徑及文件名,參數mode字符串則代表著流形態。

mode有下列幾種形態字符串:

r 打開只讀文件,該文件必須存在。

r+ 打開可讀寫的文件,該文件必須存在。

w 打開只寫文件,若文件存在則文件長度清為0,即該文件內容會消失。若文件不存在則建立該文件。

w+ 打開可讀寫文件,若文件存在則文件長度清為零,即該文件內容會消失。若文件不存在則建立該文件。

a 以附加的方式打開只寫文件。若文件不存在,則會建立該文件,如果文件存在,寫入的數據會被加到文件尾,即文件原先的內容會被保留。

a+ 以附加方式打開可讀寫的文件。若文件不存在,則會建立該文件,如果文件存在,寫入的數據會被加到文件尾後,即文件原先的內容會被保留。

上述的形態字符串都可以再加一個b字符,如rb、w+b或ab+等組合,加入b 字符用來告訴函數庫打開的文件為二進制文件,而非純文字文件。不過在POSIX系統,包含Linux都會忽略該字符。由fopen()所建立的新文件會具有S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH(0666)權限,此文件權限也會參考umask值。 返回值 文件順利打開後,指向該流的文件指針就會被返回。若果文件打開失敗則返回NULL,並把錯誤代碼存在errno 中。

附加說明 一般而言,開文件後會作一些文件讀取或寫入的動作,若開文件失敗,接下來的讀寫動作也無法順利進行,所以在fopen()後請作錯誤判斷及處理。

范例

#include<stdio.h>
main()
{
FILE * fp;
fp=fopen("noexist","a+");
if(fp= =NULL) return;
fclose(fp);
}

fread(從文件流讀取數據)

相關函數 fopen,fwrite,fseek,fscanf 表頭文件 #include<stdio.h> 定義函數 size_t fread(void * ptr,size_t size,size_t nmemb,FILE * stream); 函數說明 fread()用來從文件流中讀取數據。參數stream為已打開的文件指針,參數ptr 指向欲存放讀取進來的數據空間,讀取的字符數以參數size*nmemb來決定。Fread()會返回實際讀取到的nmemb數目,如果此值比參數nmemb 來得小,則代表可能讀到了文件尾或有錯誤發生,這時必須用feof()或ferror()來決定發生什麼情況。 返回值 返回實際讀取到的nmemb數目。

附加說明

范例

#include<stdio.h>
#define nmemb 3
struct test
{
char name[20];
int size;
}s[nmemb];
main()
{
FILE * stream;
int i;
stream = fopen("/tmp/fwrite","r");
fread(s,sizeof(struct test),nmemb,stream);
fclose(stream);
for(i=0;i<nmemb;i++)
printf("name[%d]=%-20s:size[%d]=%d/n",i,s[i].name,i,s[i].size);
} 執行 name[0]=Linux! size[0]=6
name[1]=FreeBSD! size[1]=8
name[2]=Windows2000 size[2]=11

fwrite(將數據寫至文件流)

相關函數 fopen,fread,fseek,fscanf 表頭文件 #include<stdio.h> 定義函數 size_t fwrite(const void * ptr,size_t size,size_t nmemb,FILE * stream); 函數說明 fwrite()用來將數據寫入文件流中。參數stream為已打開的文件指針,參數ptr 指向欲寫入的數據地址,總共寫入的字符數以參數size*nmemb來決定。Fwrite()會返回實際寫入的nmemb數目。 返回值 返回實際寫入的nmemb數目。 范例

#include<stdio.h>
#define set_s (x,y) {strcoy(s[x].name,y);s[x].size=strlen(y);}
#define nmemb 3
struct test
{
char name[20];
int size;
}s[nmemb];
main()
{
FILE * stream;
set_s(0,"Linux!");
set_s(1,"FreeBSD!");
set_s(2,"Windows2000.");
stream=fopen("/tmp/fwrite","w");
fwrite(s,sizeof(struct test),nmemb,stream);
fclose(stream);
}

執行

參考fread()

fseek()函數

調用形式:

#include"stdio.h"

fseek(文件類型指針fp,位移量,起始點);

函數功能:把與fp有關的文件位置指針放到一個指定位置。

其中,“位移量”是long型數據,它表示位置指針相對於“起始點”移動的字節數。如果位移量是一個正數,表示從“起始點”開始往文件尾方向移動;如果位移量是一個負數,則表示從“起始點”開始往文件頭方向移動。

“起始點”不能任意設定,它只能是在stdio.h中定義的三個符號常量之一:

起始點

對應的數字

代表的文件位置

SEEK_SET

0 文件開頭

SEEK_CUR

1 文件當前位置

SEEK_END

2 文件末尾

例如:

fseek(fp,50L,0);或fseek(fp,50L,SEEK_SET);

其作用是將位置指針移到離文件頭50個字節處。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved