linux部分系统io函数 -ag凯发k8国际
1.系统io函数:
(1)open函数:
1).首先其需要包含头文件:
#include
#include
#include
2).然后就是open的两种参数
int open(const char *pathname,int flags);
int open(const char *pathname,int flags,mode_t mode);
open会返回文件描述符返回-1则操作失败
文件描述符是在关闭文件时close(头文件#include
pathname:可以是文件路径名或者文件名,是文件名是当前路径下,路径为绝对路径
flags :是打开文件采用的操作
必选项:
o_rdonly:只读模式
o_wronly:只写模式
o_rdwr:可读可写
还有一些参数可以和上边三种一起作为flags
可选项:
o_append表示追加,如果原文件有内容这次写入会在文件最末尾
o_creat文件不存在就会创建该文件
o_excl:表示如果文件已经存在则出错同时返回-1并修改errno的值
o_trunc:如果文件存在并且以只读只写的方式打开那么长度截断为0(即删除文件内容)
mode:是设置访问权限的初始值但是不是最终权限需要与本地掩码(输入umask可获得)取反再&操作
比如权限初始为777,掩码为002,那么都转换成二进制,777对应111111111,02对应000000010进行&操作再三个三个的转换成最终权限
3)errno是全局变量
头文件==#include
当函数调用发生错误的时候将会被设置值如果函数不发生错误就无定义而且不会置0
当引用函数发生错误时可以用perror函数来将函数发生错误的原因输出
函数定义为:void perror(const char *s)
其参数的目的是用户做的标记,是用户调用函数用来干什么的时候发生了错误比如
perror(“open file”)函数在打开文件的时候发生错误,如图(本目录下是没有hsllo.c这个文件):
第二张图就可以看出来perror的参数和其要发生错误的原因的关系
4)如何查看文件已经存在(这里hsllo.c已经存在):
主要看open里边的第二个参数放的内容
(2)read和write函数:
这里他俩的头文件都是==#include
read(文件描述符,存放读取的数据,读取数据的字节数);
write(文件描述符,写入文件的数据,写入数据的字节数);
这里的read会有一个返回值是文件描述符,如果是-1则读取文件失败
如果是0则文件读取完毕
如果大于1则是读取的字节数
write为-1那么代表写入失败
write大于等于0代表写入的字节数
这里连续读取的时候文件指针文件指针自动后移
注意一定要关闭文件
以下便是具体的实例:
(3)lseek函数
头文件
#include
#include
off_lseek(int fd,off_t offset,int whence)
lseekh函数会重新定位被打开文件的偏移量
offset是偏移量字节
根据offset和whence的组合来决定
whence的值:
seek_set:从文件头部开始偏移offset个字符
seek_cur:从文件当前读写指针开始增加offset个字节的偏移量
seek_end:文件偏移量设置为文件大小加上偏移量字节
offset为正则向文件末尾移动,为负数则向文件头部向后移动
返回值为-1失败否则返回值为新的偏移量
其有三个作用:
1.获取文件大小
2.移动文件指针
3.文件拓展
下面是测试文件长度和文件拓展:
要想扩展必须有两个步骤一个是offset设置拓展的长度
另一个是再在文件末尾写点数据进去才能拓展进去
总结
以上是ag凯发k8国际为你收集整理的linux部分系统io函数的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: linux下的gdb调试makefile
- 下一篇: linux下的shell编程