Linux文件编程
Linux文件编程有两种方式:
1、Linux系统调用
2、C语言库函数
前者依赖于Linux系统,后者与操作系统是独立的,在任何操作系统下,使用C语言库函数操作文件的方法都是相同的。
Linux系统调用:
#include
#include
#include
int creat(const char *filename,mode_t mode)
成功:返回文件描述符
失败:返回-1
功能:创建一个文件
filename:要创建的文件名(包含路径,缺省为当前路径)
mode:创建模式
常用的模式:
用宏表示:
S_IRUSR 可读
S_IWUSR 可写
S_IXUSR 可执行
S_IRWXU 可读、可写、可执行
用数字表示:
可执行 -> 1
可写 -> 2
可读 -> 4
无任何权限 -> 0
在Linux系统中,所有打开的文件都对应一个文件描述符。文件描述符的本质是一个非负整数。当打开一个文件时,该整数由系统来分配。
#include
#include
#include
int open(const char *pathname,int flags)
int open(const char *pathname,int flags,mode_t mode)
成功:返回文件描述符
失败:返回-1
功能:打开一个文件
filename:要创建的文件名(包含路径,缺省为当前路径)
flags:打开标志
常见打开标志:
O_RDONLY 只读方式打开
O_WRONLY 只写方式打开
O_RDWR 读写方式打开
O_APPEND 追加方式打开
O_CREAT 创建一个文件
O_NOBLOCK 非阻塞方式打开
如果使用了O_CREAT标志,则使用的函数是:
int open(const char *pathname,int flags,mode_t mode)
这时需要mode来表示文件访问权限。
#include
int close(int fd)
成功:返回0
失败:返回-1
功能:关闭文件描述符fd所指向的文件
fd:文件描述符
#include
int read(int fd,const void *buf,size_t length)
成功:返回读到文件字节数,若已到文件尾,返回0
失败:返回-1
功能:从文件描述符fd所指定的文件中读取length个字节到buf所指向的缓冲区中。
#include
int write(int fd,const void *buf,size_t length)
成功:返回已写文件字节数
失败:返回-1
功能:把length个字节从buf所指向的缓冲区写到文件描述符fd所指定的文件中。
#include
off_t lseek(int fd,off_t offset,int whence)
成功:返回新的文件偏移量
失败:返回-1
功能:将文件读写指针相对whence移动offset个字节
若whence是SEEK_SET,则将该文件的偏移量设置为距头文件开始处offset个字节
若whence是SEEK_CUR,则将该文件的偏移量设置为其当前值加offset,offset可为正或负
若whence是SEEK_END,则将该文件的偏移量设置为文件长度加offset个字节,offset可为正或负
通过一个copy历程,更好地理解上述函数:
#include
#include
#include
#include
#include
#include
#include
#define BUFFER_SIZE 1024
int main(int argc,char **argv)
{
int from_fd,to_fd;
int bytes_read,bytes_write;
char buffer[BUFFER_SIZE];
char *ptr;
if(argc!=3)
{
printf("Usage:%s fromfile tofile/n/a",argv[0]);
exit(1);
}
//打开源文件
if((from_fd=open(argv[1],O_RDONLY))==-1)
{
printf("Open %s Error",argv[1]);
exit(1);
}
//创建目的文件
if((to_fd=open(argv[2],O_WRONLY|O_CREAT,S_IRUSR|S_IWUSR))==-1)
{
printf("Open %s Error/n",argv[2]);
exit(1);
}
//以下代码是一个经典拷贝文件代码
//read函数返回值为读到字节数,出错为-1
while(bytes_read=read(from_fd,buffer,BUFFER_SIZE))
{
//读文件操作报错
if((bytes_read==-1) && (errno!=EINTR))
break;
else if(bytes_read>0)
{
ptr=buffer;
while(bytes_write=write(to_fd,ptr,bytes_read))
{
if((bytes_write==-1)&&(errno!=EINTR))
break;
//全部写完
else if(bytes_write == bytes_read)
break;
//没写完继续写
else if(bytes_write > 0)
{
ptr+=bytes_write;
bytes_read-=bytes_write;
}
}
//写的时候发生错误
if(bytes_write)break;
}
}
close(from_fd);
close(to_fd);
exit(0);
}
C语言库函数的调用不在此赘述!