3.1 文件描述符

  文件IO 系统调用是不带缓存的,文件 I/O 系统调用不是 ANSI C 的组成部分,是 POSIX 的组成部分。

  系统调用与C库:

  

  C库函数的IO 的底层还是调用系统调用 I/O。

  需要运行速度很快的时候采用 文件IO系统调用。

  FILE 结构体中有 文件描述符成员 fd,标准C的IO依然是通过 fd 来操作文件,系统调用的 文件 IO 直接使用 fd 来操作。

  • 标准库函数:遵守 ISO 标准,基于流的 I/O,对文件指针(FILE结构体)进行操作
  • 系统调用:兼容 POSIX 标准,基于文件描述符的 I/O,对文件描述符进行操作
  • 文件描述符:
    • 对于内核而言,所有打开文件都由文件描述符引用。文件描述符是一个非负整数。当打开一个现存文件或创建一个新文件时,内核向进程返回一个文件描述符。当读、写一个文件时,用 open 或 creat 返回的文件描述符标识该文件,将其作为参数传送给 read 或 write。
    • 在 POSIX 应用程序中,整数0、1、2 被替换成符号常熟 STDIN_FILENO 、STDOUT_FILENO 或STDERR_FILENO。这些常数都定义在头文件 <unistd.h> 中。
    • 文件描述符的范围是 0-- OPEN_MAX。Linux为1024(允许每个进程打开1024个文件)  

  文件描述符可以和文件指针相互转换:

  • 标准文件指针

    • stdin:0
    • stdout:1
    • stderr:2  
  • fdopen(): FILE *fdopen(int fd, const char *mode)
    • 文件描述符 转化为 文件指针  
  • fileno():int fileno(FILE *stream)
    • 文件指针转换为文件描述符  

3.2 文件IO 系统调用

3.2.1 open 函数--- 打开文件

  头文件:

  #include<sys/types.h>
  #include<sys/stat.h>
  #include<fcntl.h>

 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 以可读写方式打开文件
    • * 上述三种旗标是互斥的,也就是不可同时使用,但可与下列的标志利用OR(|)运算符组合。
    • * O_CREAT 若欲打开的文件不存在则按照 mode 参数指定的文件权限来创建文件。
    • * O_EXCL 如果O_CREAT 也被设置,此指令会去检查文件是否存在。文件若不存在则建立该文件,否则将导致打开文件错误。此外,若O_CREAT与O_EXCL同时设置,并且欲打开的文件为符号连接,则会打开文件失败。在网络文件系统仅从操作时却没有保证
    • * O_NOCTTY 如果欲打开的文件为终端机设备时,则不会将该终端机当成进程控制终端机。
    • * O_TRUNC 若文件存在并且以只读或只写的方式打开时,此标志会令文件长度清为0,而原来存于该文件的资料也会消失。
    • * O_APPEND 当读写文件时会从文件尾开始移动,也就是所写入的数据会以附加的方式加入到文件后面。
    • * O_NONBLOCK 以不可阻塞的方式打开文件,也就是无论有无数据读取或等待,都会立即返回进程之中。pathname 指的是一个FIFO、一个块特殊文件或一个字符特殊文件。
    • * O_NDELAY 同O_NONBLOCK。
    • * O_SYNC 以同步的方式打开文件。
    • * O_NOFOLLOW 如果参数pathname 所指的文件为一符号连接,则会令打开文件失败。
    • * O_DIRECTORY 如果参数pathname 所指的文件不是一个目录,则会令打开文件失败。此为Linux2.2以后特有的旗标,以避免一些系统安全问题
  • * 参数 mode 则有下列数种组合,只有在建立新文件时才会生效,此外真正建文件时的权限会受到umask值所影响,因此该文件权限应该为(mode-umaks)。
    • * S_IRWXU,00700 权限,代表该文件所有者具有可读、可写及可执行的权限。
    • * S_IRUSR 或 S_IREAD,00400 权限,代表该文件所有者具有可读取的权限。
    • * S_IWUSR 或 S_IWRITE,00200 权限,代表该文件所有者具有可写入的权限。
    • * S_IXUSR 或 S_IEXEC,00100 权限,代表该文件所有者具有可执行的权限。
    • * S_IRWXG 00070权限,代表该文件用户组具有可读、可写及可执行的权限。
    • * S_IRGRP 00040 权限,代表该文件用户组具有可读的权限。
    • * S_IWGRP 00020权限,代表该文件用户组具有可写入的权限。
    • * S_IXGRP 00010 权限,代表该文件用户组具有可执行的权限。
    • * S_IRWXO 00007权限,代表其他用户具有可读、可写及可执行的权限。
    • * S_IROTH 00004 权限,代表其他用户具有可读的权限
    • * S_IWOTH 00002权限,代表其他用户具有可写入的权限。
    • * S_IXOTH 00001 权限,代表其他用户具有可执行的权限。
  • * 返回值 成功返回文件描述符,失败则返回-1
    • * 错误代码 EEXIST 参数 pathname 所指的文件已存在,却使用了O_CREAT 和 O_EXCL 标志。
    • * EACCESS 参数 pathname 所指的文件不符合所要求测试的权限。
    • * EROFS 欲测试写入权限的文件存在于只读文件系统内
    • * EFAULT 参数 pathname 指针超出可存取内存空间
    • * EINVAL 参数 mode 不正确。
    • * ENAMETOOLONG 参数pathname太长
    • * ENOTDIR 参数pathname不是目录。
    • * ENOMEM 核心内存不足
    • * ELOOP 参数pathname有过多符号连接问题。
    • * EIO I/O 存取错误。
  • 附加说明 使用 access() 作用户认证方面的判断要特别小心,例如在 access() 后再作 open()空文件可能会造成系统安全上的问题。

3.2.2 creat 函数--- 创建文件

 #include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
int creat(const char * pathname, mode_t mode);
  • * 相关函数 read,write,fcntl,close,link,stat,umask,unlink,fopen
  • * 函数说明
    • 参数pathname指向欲建立的文件路径字符串。Creat()相当于使用下列的调用方式调用open()
    • * open(const char * pathname ,(O_CREAT|O_WRONLY|O_TRUNC), mode);
  • * 参数: 关于参数mode请参考open()函数。
  • * 返回值
    • creat()会返回新的文件描述词,若有错误发生则会返回-1,并把错误代码设给errno。
  • * 错误代码
    • EEXIST 参数 pathname 所指的文件已存在,却使用了O_CREAT 和 O_EXCL 标志。
    • * EACCESS 参数 pathname 所指的文件不符合所要求测试的权限。
    • * EROFS 欲测试写入权限的文件存在于只读文件系统内
    • * EFAULT 参数 pathname 指针超出可存取内存空间
    • * EINVAL 参数 mode 不正确。
    • * ENAMETOOLONG 参数pathname太长
    • * ENOTDIR 参数pathname不是目录。
    • * ENOMEM 核心内存不足
    • * ELOOP 参数pathname有过多符号连接问题。
    • * EMFILE 已达到进程可同时打开的文件数上限
    • * ENFILE 已达到系统可同时打开的文件数上限
  • * 附件说明
    • creat()无法建立特别的设备文件,如果需要请使用mknod()。
    • creat 的一个不足之处是它只以只写的方式打开所创建的文件。

3.2.3 close 函数--- 文件关闭

 #include<unistd.h>
int close(int fd);
  • * 函数说明

    • 当使用完文件后若已不再需要则可使用close()关闭该文件,close()会让数据写回磁盘,并释放该文件所占用的资源。
  • * 参数 fd 为先前由 open() 或 creat() 所返回的文件描述词。
  • * 返回值
    • 若文件顺利关闭则返回0,发生错误时返回-1。
  • * 错误代码
    • EBADF 参数fd 非有效的文件描述词或该文件已关闭。
  • * 附加说明
    • 虽然在进程结束时,系统会自动关闭已打开的文件,但仍建议自行关闭文件,并确实检查返回值。
    • 当一个进程终止时,它所有的打开文件都由内核自动关闭

三、文件IO——系统调用的更多相关文章

  1. 三、文件IO——系统调用(续)

    3.2.4 read 函数--- 读文件 read(由已打开的文件读取数据) #include<unistd.h> ssize_t read(int fd, void * buf, siz ...

  2. 文件IO——将文件dfs的文件内容第三个字节之后的内容复制到文件dfd中

    /* 使用文件IO将文件fds中的内容复制到文件fdd中去 1.创建两个文件描述符 2.使用open()方法分别以只读只写方式将文件描述符符文件连接 3.将读位置后移三位 4.将fds内容存储到缓冲区 ...

  3. 文件IO函数和标准IO库的区别

    摘自 http://blog.chinaunix.net/uid-26565142-id-3051729.html 1,文件IO函数,在Unix中,有如下5个:open,read,write,lsee ...

  4. (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO

    . . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...

  5. 文件IO

    在unix世界中视一切为文件,无论最基本的文本文件还是网络设备或是u盘,在内核看来它们的本质都是一样的.大多数文件IO操作只需要用到5个函数:open . read . write . lseek 以 ...

  6. select、poll、epoll三组IO复用

    int select(int nfds,fd_set* readfds,fd_set* writefds,fd_set* exceptfds,struct timeval* timeout)//其中n ...

  7. UNIX高级环境编程(14)文件IO - O_DIRECT和O_SYNC详解 < 海棠花溪 >

    春天来了,除了工作学习,大家也要注意锻炼身体,多出去运动运动.  上周末在元大都遗址公园海棠花溪拍的海棠花.   进入正题. O_DIRECT和O_SYNC是系统调用open的flag参数.通过指定o ...

  8. (代码篇)从基础文件IO说起虚拟内存,内存文件映射,零拷贝

    上一篇讲解了基础文件IO的理论发展,这里结合java看看各项理论的具体实现. 传统IO-intsmaze 传统文件IO操作的基础代码如下: FileInputStream in = new FileI ...

  9. (理论篇)从基础文件IO说起虚拟内存,内存文件映射,零拷贝

    为了快速构建项目,使用高性能框架是我的职责,但若不去深究底层的细节会让我失去对技术的热爱. 探究的过程是痛苦并激动的,痛苦在于完全理解甚至要十天半月甚至没有机会去应用,激动在于技术的相同性,新的框架不 ...

随机推荐

  1. 「SCOI2015」小凸玩矩阵 解题报告

    「SCOI2015」小凸玩矩阵 我好沙茶啊 把点当边连接行和列,在外面二分答案跑图的匹配就行了 我最开始二分方向搞反了,样例没过. 脑袋一抽,这绝壁要费用流,连忙打了个KM 然后wa了,一想这个不是完 ...

  2. 协同过滤算法 teamCF

    http://www.infoq.com/cn/articles/recommendation-algorithm-overview-part02

  3. luogu1330 封锁阳光大学 (dfs)

    给每一个联通块黑白染色(一条边两端点不同色),看是否能染 然后选那个出现次数比较少的颜色 #include<bits/stdc++.h> #define pa pair<int,in ...

  4. Dividing the Path POJ - 2373(单调队列优化dp)

    给出一个n长度的区间,然后有一些小区间只能被喷水一次,其他区间可以喷水多次,然后问你要把这个区间覆盖起来最小需要多少喷头,喷头的半径是[a, b]. 对于每个只能覆盖一次的区间,我们可以把他中间的部分 ...

  5. [HAOI2008]圆上的整点(数论)

    题目的所求可以转化为: \(y^2=r^2-x^2\)(其中r,x,y均为整数) 即\(y^2=(r-x)(r+x)\)(其中\(r,x,y\)均为整数) 不妨设\((r-x)=d*u\)------ ...

  6. CodeFroces--Joseph’s Problem

    题目意思:给出n k 求  k%1 + k%2 +k%3+...+k%n 的和 利用分块的思想 我们知道 k%i ==k-k/i*i 同时 一段连续的区间的 k/i 是相等的 #include< ...

  7. sql server 2000 个人版怎么在win7下安装

    win7 64位安装SQL2000个人版教程 首先,如果以前安装的话,要删除干净.我也找了半天的网络资料. 1.把原来sqlserver的安装目录 C:\Program Files\microsoft ...

  8. LOJ#3023 老C的键盘

    给定树,每条边有个大于号或者小于号,表示两个节点编号的大小关系.问有多少种树满足条件.n <= 100 解:树形DP. 设fij表示以i为根的子树中i是第j小的.转移的时候要乘上两个组合数. # ...

  9. A1021. Deepest Root

    A graph which is connected and acyclic can be considered a tree. The height of the tree depends on t ...

  10. redis设置最大内存