用C语言实现文件读写 *** 作
二、直接I/O文件 *** 作
这是C提供的另一种文件 *** 作,它是通过直接存/取文件来完成对文件的处理,而上篇所说流式文件 *** 作是通过缓冲区来进行;流式文件 *** 作是围绕一个 FILE指针来进行,而此类文件 *** 作是围绕一个文件的“句柄”来进行,什么是句柄呢它是一个整数,是系统用来标识一个文件(在WINDOWS中,句柄的概念扩展到所有设备资源的标识)的唯一的记号。此类文件 *** 作常用的函数如下表,这些函数及其所用的一些符号在ioh和fcntlh中定义,在使用时要加入相应的头文件。
函数 说明
open() 打开一个文件并返回它的句柄
close() 关闭一个句柄
lseek() 定位到文件的指定位置
read() 块读文件
write() 块写文件
eof() 测试文件是否结束
filelength() 取得文件长度
rename() 重命名文件
chsize() 改变文件长度
下面就对这些函数一一说明:
1open()
打开一个文件并返回它的句柄,如果失败,将返回一个小于0的值,原型是int open(const char path, int access [, unsigned mode]); 参数path是要打开的文件名,access是打开的模式,mode是可选项。表示文件的属性,主要用于UNIX系统中,在DOS/WINDOWS这个参数没有意义。其中文件的打开模式如下表。
符号 含义 符号 含义 符号 含义
O_RDONLY 只读方式 O_WRONLY 只写方式 O_RDWR 读/写方式
O_NDELAY 用于UNIX系统 O_APPEND 追加方式 O_CREAT 如果文件不存在就创建
O_TRUNC 把文件长度截为0 O_EXCL 和O_CREAT连用,如果文件存在返回错误 O_BINARY 二进制方式
O_TEXT 文本方式
对于多个要求,可以用"|"运算符来连接,如O_APPEND|O_TEXT表示以文本模式和追加方式打开文件。
例:int handle=open("c:\\msdossys",O_BINARY|O_CREAT|O_WRITE)
2close()
关闭一个句柄,原型是int close(int handle);如果成功返回0
例:close(handle)
3lseek()
定位到指定的位置,原型是:long lseek(int handle, long offset, int fromwhere);参数offset是移动的量,fromwhere是移动的基准位置,取值和前面讲的fseek()一样,SEEK_SET:文件首部;SEEK_CUR:文件当前位置;SEEK_END:文件尾。此函数返回执行后文件新的存取位置。
例:
lseek(handle,-1234L,SEEK_CUR);//把存取位置从当前位置向前移动1234个字节。
x=lseek(hnd1,0L,SEEK_END);//把存取位置移动到文件尾,x=文件尾的位置即文件长度
4read()
从文件读取一块,原型是int read(int handle, void buf, unsigned len);参数buf保存读出的数据,len是读取的字节。函数返回实际读出的字节。
例:char x[200];read(hnd1,x,200);
5write()
写一块数据到文件中,原型是int write(int handle, void buf, unsigned len);参数的含义同read(),返回实际写入的字节。
例:char x[]="I Love You";write(handle,x,strlen(x));
7eof()
类似feof(),测试文件是否结束,是返回1,否则返回0;原型是:int eof(int handle);
例:while(!eof(handle1)){……};
8filelength()
返回文件长度,原型是long filelength(int handle);相当于lseek(handle,0L,SEEK_END)
例:long x=filelength(handle);
9rename()
重命名文件,原型是int rename(const char oldname, const char newname); 参数oldname是旧文件名,newname是新文件名。成功返回0
例:rename("c:\\configsys","c:\\configw40");
10chsize();
改变文件长度,原型是int chsize(int handle, long size);参数size表示文件新的长度,成功返回0,否则返回-1,如果指定的长度小于文件长度,则文件被截短;如果指定的长度大于文件长度,则在文件后面补''\0''。
例:chsize(handle,0x12345);
;
这是因为:file=fopen("/tmp/test/test","a+");
模式 “a+” 中的 a 规定以只写打开,原文件数据保留。
因此你不能读,只能写。写的时候只能在原文件数据的末尾开始写。
即使你将文件位置指针重新定位过,
在执行写 *** 作的时候,
文件位置指针自动回到原文件数据的末尾了。
也就是原文件数据被保护起来,你是无法 *** 作的。
原文件数据无法 *** 作的定义是:不能再对原文件数据执行添加,删除,插入等。
因此,你要在原文件数据的开头插入数据,可能要绕个弯子:
1用只读模式("a") 先读出原文件数据,保存到内存
2用只写模式(“w”)清除原文件数据
3文件开头插入的信息。
4再追加原文件数据(保存在内存)
当然如果在文件末尾添加就方便多了,用 "a" 模式一步到位。
下面使用这种思路进行插入信息的示例代码:
#include <stdioh>
#include <stdlibh>
#include<stringh>
const int MAX_FILE_SIZE = 100;
//读取文件内容
int fileRead(char fileName[],char content[],int content_len)
{
FILE infile;
char ch;
infile=fopen(fileName,"r");
content_len=0;
if(infile==NULL)
{
printf("get infile eroor\n");
return 0;
}
else
{
rewind(infile);
while(EOF!=(ch=fgetc(infile)))
{
content[(content_len)++]=ch;
}
}
fclose(infile);
return 1;
}
//在文件末尾追加内容
int fileAppend(char fileName[] ,char content[],int content_len)
{
FILE outfile;
outfile=fopen(fileName,"a");
fwrite(content,content_len,1,outfile);
fclose(outfile);
}
int fileClear(char fileName[])
{
FILE file = fopen(fileName,"w");
fclose(file);
}
//在文件开头插入内容
int insetMessageInfile(char fileName[] ,char message[],int message_len)
{
char content[MAX_FILE_SIZE];
int content_len=0;
fileRead(fileName,content,&content_len);
fileClear(fileName);
fileAppend(fileName,message,strlen(message));
fileAppend(fileName,content,content_len);
}
int main(void) {
char fileName[] = "datatxt";
char msg[3]="12";
//文件内容缓存区
char content[MAX_FILE_SIZE];
int content_len=0;
int i;
fileRead(fileName,content,&content_len);
for(i=0;i<content_len;i++) printf("%c",content[i]);
printf("\n");
insetMessageInfile("datatxt",msg,strlen(msg));
fileRead(fileName,content,&content_len);
for(i=0;i<content_len;i++) printf("%c",content[i]);
printf("\n");
return EXIT_SUCCESS;
}
1、首先使用VS新建空工程,直接点击确定。
2、点击新建项选项新建c文件,用于C语言编译器,输入mainc文件。
3、然后新建一个C文件。
4、将上述参考代码,复制到mainc文件内,直接编译即可。
5、编译完成后,运行exe程序,执行后就显示出了txt文件内容。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)