Linux中文件编程可以使用两种方法:
Linux系统调用
C语言库函数
前者依赖于Linux系统,后者与操作系统是独立的,在任何操作系统下,使用C语言库函数操作文件的方法都是相同的。
系统调用-创建
int creat(const char *filename,
mode_t mode)
v filename:要创建的文件名(包含路径,缺省为当
前路径)
v mode:创建模式
常见创建模式:
S_IRUSR
可读
S_IWUSR
可写
S_IXUSR
可执行
S_IRWXU
可读、写、执行
除了可以使用上述宏以外,还可
使用数字来表示文件的访问权限
v可执行 ->1
v可写 ->2
v可读 ->4
v上述值的和,如可写可读 ->6
v无任何权限 ->0
实例分析与演示
#include
#include
//stdlib 头文件里包含了C、C++语言的最常用的
系统函数。 类型例如
size_t、wchar_t、div_t、ldiv_t和lldiv_t; 宏例如EXIT_FAILURE、EXIT_SUCCESS、
RAND_MAX和MB_CUR_MAX等等; 常用的函数如malloc()、calloc()、realloc()、free()、system()、atoi()、atol()、rand()、srand()、exit()等等
#include
#include
/
该头文件包含
open
,
read
,
write
,
close
等系统调用
void create_file(char *filename)
{
if(creat(filename,0666)<0)
//文件所有者,组,其他人
{
printf("create file %s failure!\n",filename);
exit(EXIT_FAILURE);
}
else
{
printf("create file %s success!\n",filename);
}
}
int main(int argc,char *argv[])
{
if(argc<2)
{
printf("you haven't input the filename,please try again!\n");
exit(EXIT_FAILURE);
}
create_file(argv[1]);
exit(EXIT_SUCCESS);
}
注明:
int open(const char *pathname,int flags,
mode_t mode);
这时需要指定mode来表示文件的访问权限。
#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)
{
fprintf(stderr,"Usage:%s fromfile tofile/n/a",argv[0]);
exit(1);
}
if((from_fd=open(argv[1],O_RDONLY))==-1)
{
fprintf(stderr,"Open %s Error:%s/n",argv[1],strerror(errno));
exit(1);
}
if((to_fd=open(argv[2],O_WRONLY|O_CREAT,S_IRUSR|S_IWUSR))==-1)
{
fprintf(stderr,"Open %s Error:%s/n",argv[2],strerror(errno));
exit(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==-1)break;
}
}
close(from_fd);
close(to_fd);
exit(0);
}
当我们操作完文件以后,需
件:
int close(int fd)
fd: 文件描述符,来源?
系统调用-读
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所指向的文件中,返回
值为实际写入的字节数。
系统调用-定位
intlseek(int fd, offset_t offset, int whence)
功能:
将文件读写指针相对whence移动offset
个字节。操作成功时,返回文件指针相
对于文件头的位置。
系统调用-定位
whence可使用下述值:
SEEK_SET:相对文件开头
SEEK_CUR:相对文件读写指针的当前位置
SEEK_END:相对文件末尾
offset可取负值,表示向前移动。例如下述调用
可将文件指针相对当前位置向前移动5个字节:
lseek(fd, -5, SEEK_CUR)
如何利用lseek来计算文件长度?
由于lseek函数的返回值为文件指针相对
于文件头的位置,因此下面调用的返回
值就是文件的长度:
lseek(fd, 0, SEEK_END)
系统调用-访问判断
有时我们需要判断文件是否可以进行某种操作(读,写
等),这时可以使用access函数:
int access(const char*pathname,int mode)
pathname:文件名称
mode:要判断的访问权限。可以取以下值或者是他们的
组合。R_OK:文件可读,W_OK:文件可写,X_OK:
文件可执行,F_OK文件存在。
返回值:当我们测试成功时,函数返回0,否则如果一个条
件不符时,返回-1。
例:
#include
int main()
{
if (access(“/etc/passwd”,R_OK) ==0)
printf(“/etc/passwd can be read!\n”);
}
前者依赖于Linux系统,后者与操作系统是独立的,在任何操作系统下,使用C语言库函数操作文件的方法都是相同的。
系统调用-创建
int creat(const char *filename,
mode_t mode)
v filename:要创建的文件名(包含路径,缺省为当
前路径)
v mode:创建模式
常见创建模式:
S_IRUSR
S_IWUSR
S_IXUSR
S_IRWXU
除了可以使用上述宏以外,还可
使用数字来表示文件的访问权限
v可执行 ->1
v可写 ->2
v可读 ->4
v上述值的和,如可写可读 ->6
v无任何权限 ->0
实例分析与演示
#include
#include
#include
#include
void
{
}
int main(int argc,char *argv[])
{
}
注明:
main(int argc,char *argv[])如果使用了O_CREATE标志,则使用的函数是:
argc和argv是main函数里2个参数
在控制台输入可执行文件后,然后空格参数,这样就能将参数带入到程序中
例如可执行文件名称为test.exe,参数s
test.exe s
这样argc为2(算上test.exe 和 s)
argv[0]="test.exe"
argv[1]="s"
文件描述
在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:要打开的文件名(包含路径,缺省为当
前路径)
flags:打开标志
常见的打开标志:
O_RDONLY只读方式打开
O_WRONLY只写方式打开
O_RDWR读写方式打开
O_APPEND追加方式打开
O_CREAT创建一个文件
O_NOBLOCK非阻塞方式打开
int open(const char *pathname,int flags,
mode_t mode);
这时需要指定mode来表示文件的访问权限。
当我们操作完文件以后,需
件:
int close(int fd)
fd: 文件描述符,来源?
系统调用-读
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所指向的文件中,返回
值为实际写入的字节数。
系统调用-定位
intlseek(int fd, offset_t offset, int whence)
功能:
将文件读写指针相对whence移动offset
个字节。操作成功时,返回文件指针相
对于文件头的位置。
系统调用-定位
whence可使用下述值:
SEEK_SET:相对文件开头
SEEK_CUR:相对文件读写指针的当前位置
SEEK_END:相对文件末尾
offset可取负值,表示向前移动。例如下述调用
可将文件指针相对当前位置向前移动5个字节:
lseek(fd, -5, SEEK_CUR)
如何利用lseek来计算文件长度?
由于lseek函数的返回值为文件指针相对
于文件头的位置,因此下面调用的返回
值就是文件的长度:
lseek(fd, 0, SEEK_END)
系统调用-访问判断
有时我们需要判断文件是否可以进行某种操作(读,写
等),这时可以使用access函数:
int access(const char*pathname,int mode)
pathname:文件名称
mode:要判断的访问权限。可以取以下值或者是他们的
组合。R_OK:文件可读,W_OK:文件可写,X_OK:
文件可执行,F_OK文件存在。
返回值:当我们测试成功时,函数返回0,否则如果一个条
件不符时,返回-1。
例:
#include
int main()
{
if (access(“/etc/passwd”,R_OK) ==0)
printf(“/etc/passwd can be read!\n”);
}