Linux下文件IO

 

标准IO

文件IO

遵循标准ANSIC

遵循标准POSIX

带缓冲

无缓冲,每次都会执行系统调用

使用流 FILE 描述打开的文件

通过文件描述符 来描述打开的文件

 

文件IO介绍:

  1. posix(可移植操作系统接口)定义的一组函数
  2. 不提供缓冲机制,每次读写操作都引起系统调用
  3. 核心概念是文件描述符
  4. 访问各种类型文件
  5. Linux下,标准IO基于文件IO实现

 

文件描述符

  1. 每个打开的文件都对应一个文件描述符
  2. 文件描述符是一个非负整数。Linux为程序中每个打开的文件分配一个文件描述符
  3. 文件描述符从0开始分配,依次递增
  4. 文件IO操作通过文件描述符完成
  5. 1,2,3含义:分别对应标准输入stdin 标准输出stdout 标准错误stderr

打开文件—open

#include <fcntl.h>

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

成功时返回文件描述符,错误返回EOF

打开文件时使用两个参数

创建文件时第三个参数指定新文件的权限

只能打开设备文件

第三个参数

R/W/X分别表示读/写/执行权限

S_IRUSR:用户读权限

S_IWUSR:用户写权限

S_IRGRP:用户组读权限

S_IWGRP:用户组写权限

S_IROTH:其他组都权限

S_IWOTH:其他组写权限

 

关闭文件—close()

#include <unistd.h>

int close(int fd);

 

成功时返回0;出错返回EOF

程序结束时自动关闭所有打开的文件

文件关闭后,文件描述符不再代表文件

读文件—read()

#include <unistd.h>

Ssize_t read(int fd,void *buf,size_t count);

 

成功时返回实际读取到的字节数,出错返回EOF

读到文件末尾返回0

buf是接收缓冲区

count不应超过buf大小

写文件—write()

ssize_t write(int fd,void *buf,size_t count);

成功时返回实际写入字节数,出错返回EOF

buf是发送数据的缓冲区

count不应超过buf大小

定位文件—lseek()

#include <unistd.h>

off_t lseek(int fd,off_t offset,int whence);

成功时返回当前文件读写位置,出错返回EOF

whence参数:基准点

              SEEK_SET 文件开始位置

              SEEK_CUR 文件当前读写位置

              SEEK_END 文件末尾

              offset 偏移量,可正可负

              0 文件开始位置

              流的读写位置 = 偏移量 + 基准点

 

使用文件IO对文件进行复制

#include <stdio.h>

#include <unistd.h>

#include <fcntl.h>

#include <errno.h>

#include <string.h>

 

#define N 64

 

int main(int argc,char *argv[])

{

       int fds,fdt,n;

       char buf[N];

 

       if(argc < 3)

       {

              printf("Usage : %s <src_file> <dst_file>\n",argv[0]);

              return -1;

       }

       if((fds = open(argv[1],O_RDONLY)) == -1)

       {

              //fprintf(stderr,"open %s :%s\n",argv[1],perror(errno));

              return -1;

       }

       if((fdt = open(argv[2],O_WRONLY | O_CREAT | O_TRUNC,0666)) == -1)

       {

       //     fprintf(stderr,"open %s : %s\n",argv[2],perror(errno));

              return -1;

       }

       while((n = read(fds,buf,N)) > 0)

       {

              write(fdt,buf,n);     

       }

       close(fds);     

       close(fdt);

}

 

 

 

访问目录

opendir()是用来打开一个目录文件

#include <dirent.h>

DIR *opendir(const char *name);

 

DIR是用来描述一个打开的目录文件的结构体类型

成功时返回目录流指针,失败返回NULL

 

readdir()函数用来读取目录流中的内容

#include <dirent.h>

struct dirent *readdir(DIR *dirp);

 

struct dirent 是用来描述目录流中一个目录项的结构体类型

包含成员char d_name[256] 参考帮助文档

成功时返回目录流dirp中下一个目录项,出错或者到末尾返回NULL

 

closedir() 函数关闭一个目录文件

#include <dirent.h>

int closedir(DIR *dirp);

 

成功返回0,出错返回EOF

 

修改文件访问权限

#include <sys/stat.h>

int chmod(const char *path,mode_t mode);

int fchmod(int fd,mode_t mode);

 

成功返回0 失败返回EOF

root 和文件所有者能修改文件的访问权限

示例 chmod(“test.txt”,0666);

获取文件属性—stat/lstat/fstat/

#include <sys/stat.h>

int stat(const char *path,struct stat *buf);

int lstat(const char *path,struct stat *buf);

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

 

成功时返回0  失败返回EOF

若path是符号链接   stat获取的是目标文件的属性;而lstat获取的是链接文件的属性

 

struct stat是存放文件属性的结构体类型:
mode_t  st_mode      类型和访问权限

uid_t  st_uid                  所有者id

uid_t  st_gid                  用户组id

off_t  st_size                文件大小

time_t  st_mtime           最后修改时间

 

文件类型

S_ISREG ( ) 普通文件

S_ISDIR ( ) 目录文件

S_ISCHR ( ) 字符特殊文件

S_ISBLK ( ) 块特殊文件

S_ISFIFO ( ) 管道或F I F O

S_ISLNK ( ) 符号连接( P O S I X . 1或S V R 4无此类型)

S_ISSOC K ( ) 套接字(P O S I X . 1或S V R 4无此类型)

 

st_mode 和 0170000 与完之后 与下面的几种进行对比,查看是那种文件

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

点灯师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值