这里以复制文件test到test1为例,例举了Linux编程的基本文件操作,代码如下:
//============================================================================
// Name : FileTest.cpp
// Author : Lin
// Version :
// Copyright : Your copyright notice
// Description : File Process
//============================================================================
#include <iostream>
#include <cstdio>
#include <unistd.h>
#define BUF_SIZE 20
using namespace std;
int main()
{
char *fromPath = "/home/lin/桌面/test";
char *toPath = "/home/lin/桌面/test1";
FILE *fromFile, *toFile; //FILE数据类型包含在头文件<cstdio>中
char buffer[BUF_SIZE];
int rdCnt;
int wrCnt;
int len = 0;
if ((fromFile = fopen(fromPath, "rt+")) < 0) //fopen包含在头文件<cstdio>中
{
cerr << "open test error!" << endl;
return -1;
}
if ((toFile = fopen(toPath, "rt+")) < 0)
{
cerr << "open test1 error!" << endl;
return -1;
}
while ((rdCnt = fread(buffer, sizeof(char), BUF_SIZE, fromFile)) > 0) //第二次fread将从第一次fread结束的位置开始,fwrite同理
{
if ((wrCnt = fwrite(buffer, sizeof(char), rdCnt, toFile)) != rdCnt) //这里的第三个参数是实际读进来的字节数
{
cerr << "write error!" << endl;
return -1;
}
else
{
len += wrCnt;
cout << len << " bytes has been write!" << endl;
}
}
if (rdCnt < 0)
{
cerr << "read error!" << endl;
return -1;
}
fclose(fromFile);
fclose(toFile);
cout << "success!" << endl;
return 0;
}
程序有几个要注意的地方:
fopen()和open()的区别:
1 fopen()是ANSI C函数,跨平台,而open()是Linux提供的库调用,没事少用点。。。2 fopen()一族的函数为fread,fclose等,而open()组的函数为read(),close()等
3 fopen()返回的是一个文件指针,所以fopen()一族的函数操作的是一个文件指针,而open()返回的是一个文件描述符
4 fread()fwrite()都带缓冲,而read()write()没有
还有一个需要注意的地方,写Linux文本文件的时候,不能把C语言字符串最后的‘\0’写进去,否则会造成编辑器打开文件错误。
顺带备注一下fopen()函数和open()函数头文件:
定义函数#include<cstdio>
FILE * fopen(const char * path,const char * mode);
函数说明
参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态。
mode有下列几种形态字符串:
r 打开只读文件,该文件必须存在。
r+ 打开可读写的文件,该文件必须存在。
rb+ 读写打开一个二进制文件,只允许读写数据。
rt+ 读写打开一个文本文件,允许读和写。
w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失。若文件不存在则建立该文件。
w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。(EOF符保留)
a+ 以附加方式打开可读写的文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。 (原来的EOF符不保留)
wb 只写打开或新建一个二进制文件;只允许写数据。
wb+ 读写打开或建立一个二进制文件,允许读和写。
wt+ 读写打开或着建立一个文本文件;允许读写。
at+ 读写打开一个文本文件,允许读或在文本末追加数据。
ab+ 读写打开一个二进制文件,允许读或在文件末追加数据。
上述的形态字符串都可以再加一个b字符,如rb、w+b或ab+等组合,加入b 字符用来告诉函数库打开的文件为二进制文件,而非纯文字文件。不过在POSIX系统,包含Linux都会忽略该字符。由fopen()所建立的新文件会具有S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH(0666)权限,此文件权限也会参考umask 值。
定义函数:#include <sys/types.h> #include <sys/stat.h> #include <fcntl.h>
int open(const char * pathname, int flags);
int open(const char * pathname, int flags, mode_t mode);
函数说明:
参数 pathname 指向欲打开的文件路径字符串. 下列是参数flags 所能使用的旗标:
O_RDONLY 以只读方式打开文件
O_WRONLY 以只写方式打开文件
O_RDWR 以可读写方式打开文件. 上述三种旗标是互斥的, 也就是不可同时使用, 但可与下列的旗标利用OR(|)运算符组合.
O_CREAT 若欲打开的文件不存在则自动建立该文件.如果第二个参数设置了O_CREATE则需要设置新建的文件的用户权限,即第三个参数
参数mode 则有下列数种组合, 只有在建立新文件时才会生效, 此外真正建文件时的权限会受到umask 值所影响, 因此该文件权限应该为 (mode-umaks).
S_IRWXU00700 权限, 代表该文件所有者具有可读、可写及可执行的权限.
S_IRUSR 或S_IREAD, 00400 权限, 代表该文件所有者具有可读取的权限.
S_IWUSR 或S_IWRITE, 00200 权限, 代表该文件所有者具有可写入的权限.
S_IXUSR 或S_IEXEC, 00100 权限, 代表该文件所有者具有可执行的权限.
S_IRWXG 00070 权限, 代表该文件用户组具有可读、可写及可执行的权限.
S_IRGRP 00040 权限, 代表该文件用户组具有可读的权限.
S_IWGRP 00020 权限, 代表该文件用户组具有可写入的权限.
S_IXGRP 00010 权限, 代表该文件用户组具有可执行的权限.
S_IRWXO 00007 权限, 代表其他用户具有可读、可写及可执行的权限.
S_IROTH 00004 权限, 代表其他用户具有可读的权限
S_IWOTH 00002 权限, 代表其他用户具有可写入的权限.
S_IXOTH 00001 权限, 代表其他用户具有可执行的权限.