关于linux编程:基础IO
关上文件(open函数)任何一个过程在运行时都会默认关上三个文件 规范输出stdin(键盘)规范输入stdout(显示器)规范谬误stderr(显示器)open函数原型pathname :要关上的文件门路。mode :指定要用什么权限关上文件。返回值 :关上失败则返回 -1,关上胜利则返回一个文件描述符。int open(const char *pathname, int flags); //用于关上曾经存在的文件int open(const char *pathname, int flags, mode_t mode); //用于关上不存在的文件文件权限mode创立文件时,mode用于设定新文件的权限。 该权限是以权限编码值来设定的(例如设置为 0666 )该权限受权限掩码umask的限度。 flags属性详解关上文件的形式: O_RDONLY :示意以只读形式关上。O_WRONLY :示意以只写形式关上。O_RDWR :示意以可读可写形式关上。写入数据的形式: O_APPEND :写入数据时,以在开端追加的形式写入。O_TRUNC :写入数据时,以笼罩的形式写入(即先删除原数据,再写入)如果同时应用 :O_TRUNC起作用同时不应用 :原文件内容不变(不读不写)关上不存在的文件时: O_CREAT :关上不存在的文件时,会在以后门路主动创立这个文件,如果文件存在,则会先删除这个文件再创立文件。所谓以后门路是指过程启动时所处的门路,而不是程序文件所存在的门路。读文件(read)函数原型fd :文件描述符buf :寄存读取的数据count:冀望读取的字节数返回值是理论读取的字节数。#include <unistd.h>ssize_t read(int fd, void *buf, size_t count);写文件(write)函数原型fd :文件描述符buf :须要写入的内容count:冀望写入的字节数返回值是理论写入的字节数。#include <unistd.h>ssize_t write(int fd, const void *buf, size_t count); C语言中的fopen、fwrite、freadc语言中的文件函数fopen等,其底层都是调用零碎的open函数等。并且 fopen 等返回值为文件指针, open 返回值是文件描述符(int类型)这样实现一种语言上的封装,实现跨平台性。文件描述符在零碎中任何时刻都存在大量的曾经关上的文件。磁盘文件中存储的不只是文件内容,还包含文件属性内存文件中存储的更多是文件属性,文件内容是迟缓的从硬盘文件中加载的。零碎调配文件描述符的办法: 以后曾经应用的文件描述符不会再次被调配,新调配的文件描述符的值是零碎中未被调配的文件描述符的值中最小的一个。文件描述符的意义每个过程中都存在一个过程管制块PCB这个PCB的构造体task_struct中存在一个文件构造体 files_struct这个文件构造体中存在一个用来存在文件指针的数组 struct file* fd_array [ ]运行过程,关上文件后,就会将文件的指针寄存在这个数组中所谓的文件描述符则是对应文件在数组中的下标。因为过程的独立性,在这个过程中将文件敞开,对其余过程没有影响。复制文件描述符dup函数介绍调用dup函数对文件描述符fd1进行复制,会返回一个新的文件描述符(留神:这个新的文件描述符fd2 在数值上不等于 fd1,然而它们都指向同一个文件)应用dup复制时,这个新的文件描述符 fd2 的值是无奈本人指定的,是由操作系统外部调配的。#include <unistd.h>int dup(int oldfd);//fd2 = dup(fd1);dup2函数介绍应用dup2 复制时,这个新的文件描述符的值是能够本人指定的。fd1 是原来的文件描述符的值,16 是人为指定新的文件描述符。如果正确,返回值fd2 就是16,如果谬误,返回值fd2 就是 -1。#include <unistd.h>int dup2(int oldfd, int newfd);//fd2 = dup2(fd1, 16);命令行中的重定向( > )Linux中的shell命令执行后,打印后果都是默认进入规范输入的(因为这些命令都是调用printf打印的),所以咱们能够间接在Linux终端看到命令执行的后果。命令行中的重定向 > 的作用: ...