c语言nmemb,二进制文件的读写(C语言,C++)

相关函数

open,fclose

表头文件

#include

定义函数

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

main()

{

FILE * fp;

fp=fopen("noexist", "a+");

if( fp == NULL) return;

fclose(fp);

}

fread(从文件流读取数据)

相关函数

fopen,fwrite,fseek,fscanf

表头文件

#include

定义函数

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

#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

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

定义函数

size_t fwrite(const void * ptr, size_t size, size_t nmemb, FILE * stream);

函数说明

fwrite()用来将数据写入文件流中。参数stream为已打开的文件指针,参数ptr 指向欲写入的数据地址,总共写入的字符数以参数size*nmemb来决定。Fwrite()会返回实际写入的nmemb数目。

返回值

返回实际写入的nmemb数目。

范例

#include

#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()。

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=516255

下面是用C++实现二进制文件的读写:

本文读写文件均使用文件流进行操作,主要使用的类是ifstream, ofstream, 使用时,请务必包含文件fstream。如下:

#include

写二进制文件:

写二进制文件应该使用ofstream类,文件的打开模式一定要是 binary,如果传入的不是 binary, 文件将以ASCII方式打开。

下面是示例代码,用于写入文件。

std::ofstream fout("a.dat", std::ios::binary);

int nNum = 20;

std::string str("Hello, world");

fout.write((char*)&nNum, sizeof(int));

fout.write(str.c_str(), sizeof(char) * (str.size()));

fout.close();

而写文本文件则比较简单,如下:

std::ofstream fout("b.dat");

int nNum = 20;

std::string str("Hello, world");

fout << nNum << "," << str << std::endl;

fout.close();

读二进制文件:

读取二进制文件可以使用ifstream 类来进行,文件的打开模式一定要是 binary,如果传入的不是 binary, 文件将以ASCII方式打开。

下面是示例代码:

std::ifstream fin("a.dat", std::ios::binary);

int nNum;

char szBuf[256] = {0};

fin.read((char*)&nNum, sizeof(int));

fin.read(szBuf, sizeof(char) * 256);

std::cout << "int = " << nNum << std::endl;

std::cout << "str = " << szBuf << std::endl;

fin.close();

而读取文本文件则比较简单:

std::ifstream fin("b.dat");

int nNum;

char szBuf[256] = {0};

fin >> nNum >> szBuf;

std::cout << "int = " << nNum << std::endl;

std::cout << "str = " << szBuf << std::endl;

fin.close();

文件的打开模式:

文件操作时,如果不显示指定打开模式,文件流类将使用默认值。

在 中定义了如下打开模式和文件属性:

ios::app  // 从后面添加

ios::ate  // 打开并找到文件尾

ios::binary  // 二进制模式I/O(与文本模式相对)

ios::in  // 只读打开

ios::out  // 写打开

ios::trunc  // 将文件截为 0 长度

可以使用位操作符 OR 组合这些标志,比如

ofstream logFile("log.dat", ios::binary | ios::app);

二进制文件的复制:

这里我实现了一个二进制文件的复制操作,用于验证读写的正确性,示例代码如下:

view plain

copy to clipboard

print

?

bool copy_binary_file(const char * szDestFile, const char * szOrigFile) { if (szDestFile == NULL) { return false; } if (szOrigFile == NULL) { return false; } bool bRet = true; std::ofstream fout(szDestFile, std::ios::binary | std::ios::app); std::ifstream fin(szOrigFile, std::ios::binary); if (fin.bad()) { bRet = false; } else { while(!fin.eof()) { char szBuf[256] = {0}; fin.read(szBuf, sizeof(char) * 256); if (fout.bad()) { bRet = false; break; } // fout.write(szBuf, sizeof(char) * 256); } } fin.close(); fout.close(); return bRet; }

后记

由于文本文件本质上也是磁盘上的一个个二进制编码,因此,读写二进制文件的代码同样可以读写文本文件,在文件类型不是很明确的读写操作中,直接使用二进制读写比较可取,如果可以直接判断文件类型,则可以分别对待。

关于读取文本文件,请参照http://blog.csdn.net/lightlater/archive/2011/04/15/6326338.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值