Linux系统IO接口
1.联系与区别
拿C语言来说,我们知道它有自己的C文件IO接口,像open,close,write,read,lseek等等,并且·默认会打开按个输入输出流,分别是stdin,stdout,stderr,并且他们的类型都是FILE*,文件指针类型。那么在Linux系统下也有它自己的IO接口,两者有什么不同吗?下面我们结合代码来看:
系统的open接口(该段程序是往myfile里面循环写入count次的hello bit!)
1.#include <stdio.h>
2 #include <sys/types.h>
3 #include <sys/stat.h>
4 #include <fcntl.h>
5 #include <unistd.h>
6 #include <string.h>
7
8 int main( void )
9 {
10 umask(0);
11 int fd = open("myfile", O_WRONLY|O_CREAT,0644);
12 if( fd < 0 ){
13 perror("open");
14 return 1;
15 }
16
17 int count = 5;
18 const char *msg = "hello bit!\n";
19 int len = strlen(msg);
20
21 while(count--){
22 write(fd,msg,len); //msg缓冲区首地址,len本次期望写入多少个字节数 返回值:实际写入了多少个字节数
23 }
24
25 close(fd);
26 return 0;
27 }
运行结果:
C
C的open接口
运行结果为:
可以看出两个的作用感觉是一样的,但是一个是系统接口,一个C的库函数,我们看一张图来说明
可以看出来f#系列的函数都是对系统函数的封装,为了方便二次开发
2.常见的系统IO接口
open
打开文件
#include <fcntl.h>
int open(const char *pathname,//要打开的文件名
int flags,//O_RDNLY只读
//O_RWONLY只写
//O_RDWR读写
//O_APPEND追加
//O_CTEAT创建文件
//O_EXCL必须跟O_CREAT一起使用,如果文件存在就报错
//O_TRUNC 清空文件原有内容
mode_t mode);//如果是创建文件加权限
返回值: 成功>=0,代表已经打开的文件
失败-1
write
写文件
ssize_t write(int fd,//
const void *buf,//想要写出去的数据在哪里
size_t count)//数据的个数
返回值:表示实际写出去多少个字节
read
读文件
ssize_t read(int fd,//open打开的文件描述符
void *buf,//读取的内容装到这里
size_t count)//这个地方的大小
typedef int ssize_t
typedef unsigned int size_t
返回值:实际读取的字节数 0表示读到文件结尾,-1出错
实际读取的字节数,不一定等于count
close
关闭文件
int close(int fd);