系统调用方式访问文件
linux文件编程可以使用两种方法:
1、linux系统调用
2、c语言库函数
前者依赖于linux系统,后者与操作系统是独立的,在任何操作系统下,使用c语言库函数操作文件的方法都是相同的。
系统调用——创建
int creat(const char *fileanme , mode_t mode)filename:要创建的文件名(包含路径,缺省为当前路径)
mode:创建模式(rwx)
常见创建模式:
S_IRUSER 可读(4)
S_IWUSER 可写(2)
S_IXUSER 可执行(1)
S_IRWXU 可读、写、执行
无任何权限为0
argc:参数的个数
argv:参数的值保存在argv这个字符串数组里
文件描述
在linux系统中,所有打开的文件都对应一个文件描述符。文件描述符的本质是一个非负整数,当打开一个文件时,该整数由系统来分配。文件描述符的范围是0-OPEN_MAX。早期的UNIX版本的OPEN_MAX=19,即每个线程最多同时打开20个文件,现在很多系增加至1024.系统调用-打开(两种模式)
int open(const char *pathname,int flags)int open(const char *pathname,int flags,mode_t mode)
pathname:要打开文件名(包含路径,缺省为当前路径)
flag:打开标志
常见打开标志:
O_RDONLY:只读方式打开
O_WRONLY只写方式打开
O_RDWR读写方式打开
O_APPEND追加方式打开
O_CREATE创建一个文件
O_NOBLOCK非阻塞方式打开
如果使用了O_CREATE 标志,则使用函数是;
int open(const char *pathname,int flags,mode_t mode)
这时需要指定mode来表示文件的访问权限。(创建的时候需要指定文件的属性)
系统调用-关闭
当我们操作完文件以后,需要关闭文件:int close(int fd)
fd:文件描述符,(系统分布从open系统调用获取
系统调用-读
int read(int fd,const void *buf,size_t length)功能:从文件描述符fd所指定的文件中读取length个字节到buf所指向的缓冲区中,返回值为实际度取得的字节数。
系统调用-写
int write(int fd,const void*buf,size_t length)功能:把length个字节从buf所指向的缓冲区中写到文件描述符fd所指向的文件中,返回值为实际写入的字节数。
系统调用-定位(指针操作)
int lseek(int fd,offset_t offset,int whence)功能:将文件读写指针相对whence移动offset个字节。操作成功时返回文件指针相对于文件头的位置。
whence可以使用一下述值:
SEEK_SET:相对于文件开头
SEEK_CUR:相对文件读写指针的当前位置
SEEK_END:相对文件末尾
offset可取负值,表示向前移动。
例如:lseek(fd,-5,SEEK_CUR)表示可将文件指针相对当前位置向前移动5个字节。
系统调用-访问判断
有时候我们需要判断文件是否可以进行哪种操作(rwx)这时候我们可以使用access函数:iint access(const shar*pathname,int mode)
pathname:文件名
mode:要判断访问权限。可以取一下值或者是他们的组合。R_OK:文件可读,W_OK:文件可写,X_OK:文件可执行,F_OK文件存在。
返回值:当测试成功时返回0,否则一个条件不符时,返回-1.
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <fcntl.h>
#define BUFFER_SIZE 1024
/*
* 程序入口
* */
int main(int argc,char **argv)
{
int from_fd, to_fd;
long file_len=0;
int ret=1;
char buffer[BUFFER_SIZE];
char *ptr;
/*判断入参*/
if(argc!=3)
{
printf("Usage:%s fromfile tofile\n",argv[0]);
exit(1);
}
/*打开原文件*/
if((from_fd=open(argv[1], O_RDONLY|O_CREAT))==-1)
{
printf("Open %s Error\n",argv[1]);
exit(1);
}
/*创建目标文件*/
if((to_fd=open(argv[2], O_WRONLY|O_CREAT))==-1)
{
printf("Open %s Error\n",argv[2]);
exit(1);
}
/*测的文件大小*/
file_len= lseek(from_fd,0L,SEEK_END);
lseek(from_fd,0L,SEEK_SET);
printf("form file size is %d\n",file_len);
/*进行文件拷贝*/
while(ret)
{
ret= read(from_fd, buffer, BUFFER_SIZE);
if(ret==-1)
{
printf("read Error\n");
exit(1);
}
write(to_fd, buffer, ret);
file_len-=ret;
bzero(buffer,BUFFER_SIZE);
}
printf("there are %d byte(s) data left without copy\n", file_len);
close(from_fd);
close(to_fd);
exit(0);
}