Linux下C语言编程——文件操作

时间:2021-09-16 13:05:06

 

#include <fcntl.h>;

#include <unistd.h>;

#include <sys/types.h>;

#include <sys/stat.h>;

 

int open(const char *pathname,int flags);

int open(const char *pathname,int flags,mode_t mode);

int close(int fd);

 

open 函数有两个形式.其中 pathname 是我们要打开的文件名(包含路径名称,缺省是认为在

当前路径下面).flags 可以去下面的一个值或者是几个值的组合.

 

O_RDONLY:以只读的方式打开文件.

O_WRONLY:以只写的方式打开文件.

O_RDWR:以读写的方式打开文件.

O_APPEND:以追加的方式打开文件.

O_CREAT:创建一个文件.

O_EXEC:如果使用了 O_CREAT 而且文件已经存在,就会发生一个错误.

O_NOBLOCK:以非阻塞的方式打开一个文件.

O_TRUNC:如果文件已经存在,则删除文件的内容.

 

前面三个标志只能使用任意的一个.如果使用了 O_CREATE 标志,那么我们要使用 open 的第

二种形式.还要指定 mode 标志,用来表示文件的访问权限 . mode 可以是以下情况的组合.

 

S_IRUSR 用户可以读 S_IWUSR 用户可以写

S_IXUSR 用户可以执行 S_IRWXU 用户可以读写执行

-----------------------------------------------------------------

S_IRGRP 组可以读 S_IWGRP 组可以写

S_IXGRP 组可以执行 S_IRWXG 组可以读写执行

-----------------------------------------------------------------

S_IROTH 其他人可以读 S_IWOTH 其他人可以写

S_IXOTH 其他人可以执行 S_IRWXO 其他人可以读写执行

-----------------------------------------------------------------

S_ISUID 设置用户执行 ID S_ISGID 设置组的执行 ID

-----------------------------------------------------------------

 

我们也可以用数字来代表各个位的标志.Linux 总共用 5 个数字来表示文件的各种权限.

00000.第一位表示设置用户 ID.第二位表示设置组 ID,第三位表示用户自己的权限位,第四位表示组的权限,最后一位表示其他人的权限.

 

每个数字可以取1(执行权限),2(写权限),4(读权限),0(什么权限也没有)。

eg:比如我们要创建一个用户读写执行,组没有权限,其他人读执行的文件.设置用户 ID 位那么

我们可以使用的模式是--1(设置用户 ID)0(组没有设置)7(1+2+4)0(没有权限,使用缺省)

5(1+4)即 10705:

open("temp",O_CREAT,10705);

 

 

文件打开后,可以进行读写:

#include<unistd.h>

ssize_t read(int fd,void *buffer,size_t count)

ssize_t write(int fd,const void *buffer,size_t vount)

fd是要进行读写操作的文件描述符,buffer是要写入文件内容或者读出文件内容的内存地址,count是我们要读出的字节数。

 

文件的属性:access()

#include<unistd.h>

int access(const char *pathname,int mode)

mode是我们要判断的属性。可以取下值或者是他们组合。R_OK文件可以读,W_OK文件可以写,X_OK可以执行,F_OK文件存在。测试成功时,返回0.要获得其他的属性,可以用stat()或者fstat。

#include<sys/stat.h>

#include<unistd.h>

int stat(const char *filename,struct stat *buf)

int fstat(int filedes,struct stat *buf);

 

struct stat {

dev_t st_dev; /* 设备 */

ino_t st_ino; /* 节点 */

mode_t st_mode; /* 模式 */

nlink_t st_nlink; /* 硬连接 */

uid_t st_uid; /* 用户 ID */

gid_t st_gid; /* 组 ID */

dev_t st_rdev; /* 设备类型 */

off_t st_off; /* 文件字节数 */

unsigned long st_blksize; /* 块大小 */

unsigned long st_blocks; /* 块数 */

time_t st_atime; /* 最后一次访问时间 */

time_t st_mtime; /* 最后一次修改时间 */

time_t st_ctime; /* 最后一次改变时间(指属性) */

};

stat用来判断没有打开的文件,而fstat用来判断打开的文件 ,我们使用的最多的属性是st_mode, 通过这属性我们可以判断给定的文件是一个普通文件还是一个目录,连接等等,可以用下面几个宏来判断。

S_ISLNK(st_mode):是否是一个连接.

S_ISREG 是否是一个常规文件.

S_ISDIR 是否是一个目录

S_ISCHR 是否是一个字符设备.

S_ISBLK 是否是一个块设备 

S_ISFIFO 是否 是一个 FIFO文件.

S_ISSOCK 是否是一个 SOCKET 文件.

 

目录文件的操作:得到当前的工作路径,getcwd函数

#include<unistd.h>

char *getcwd(char *buffer,size_size)

目录文件操作函数:

 

 

 

 

mkdir就是创建一个目录,opendir打开一个目录为以后做准备。readdir读一个打开的目录,rewinddir是用来重读目录。closedir是关闭一个目录,telldir和seekdir类似于free和fseek函数。

 

————————————————————————————————————————————————————————————

管道文件:系统调用pipe 可以创建一个管道。

#include<unistd.h>

int pipe(int fildes[2]);

pipe调用可以创建一个管道(通信缓冲区) 调用成功时,我们可以访问文件描述符(fildes[0],fildes[1],其中fildes[0]是用来读的文件描述符,fildes[1]是用来写的文件描述符).

 

为了实现重定向,需要另外一个函数dup2

#include<unistd.h>

int dup2(int oldfd,int newfd);

dup2将用oldfd文件描述符来代替newfd文件描述符,同时关闭newfd文件描述符,也就是说,所有向newfd操作都转到oldfd上面。