文件描述符:
1.对于内核而言,所有打开文件都由文件描述符引用。文件描述符是一个非负整数。当打开一个现存文件或者创建一个新文件时,内核向进程返回一个文件描述符。当读写一个文件时,用open和create返回的文件描述符标识该文件,将其作为参数传递给read和write.
按照惯例,UNIX shell使用文件描述符0与进程的标准输入相结合,文件描述符1与标准输出相结合,文件描述符2与标准错误输出相结合。STDIN_FILENO,STDOUT_FILENO,STDERR_FILENO这几个宏代替了0,1,2这几个魔数。
2.文件描述符,这个数字在一个进程中表示一个特定含义,当我们open一个文件时,操作系统在内存中构建了一些数据结构来表示这个动态文件,然后返回给应用程序一个数字作为文件描述符,这个数字和我们内存中维护的这个动态文件的这些数据结构绑定上了,以后我们应用程序如果要操作这个动态文件,只需要用这个文件描述符区分。
3.文件描述符的作用域就是当前进程,除了这个进程文件描述符就没有意义了。
open函数打开文件,打开成功后返回一个文件描述符,打开失败,返回-1。
1.在Linux中要操作一个文件,一般是先打开一个文件,得到文件描述符,然后对文件进行读写操作(或其他操作),最后是close关闭文件即可。
2.强调一点:我们对文件进行操作时,一点要先打开文件打开成功之后才能操作,如果打开失败,就不用进行后面的操作了,最后读写完成后,一定要关闭文件,否则会造成文件的损坏。
3.文件平时存放在设备中的文件系统文件中的,我们把这种文件叫静态文件,当我们去open打开一个文件时,Linux内核的操作包括:内核在进程中建立一个打开文件的数据结构,记录下来我们打开的这个文件;内核在内存中的申请一段内存,并且将静态文件的内容从块设备中读取到内核中特定地址管理存放(叫动态文件)。
4.文件打开后,以后对这个文件的读写操作,都是针对内存中的这一份动态文件的,而并不是针对静态文件的。当然我们对动态文件进行读写以后,此时内存中动态文件和块设备文件中的静态文件就不同步了,当我们close内部内核将内存中的动态文件的内容去更新(同步)块设备中的静态文件。
5.为什么这么设计,不直接对块设备直接操作。
块设备本身读写非常不灵活,是按块读写的,而内存是按字节单位操作的,而且可以随机操作,很灵活。
Linux系统默认标准输入与标准输出:
代码如下:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <stdlib.h>
int main()
{
int fd;
char readbuf[128]={0};
int n_read=read(0,readbuf,128);
int n_write=write(1,readbuf,strlen(readbuf));
printf("\n");
}
代码分析:文件描述符为0时代表的是标准输入,读取键盘上输入的数据,文件描述符为1时是标准输出,把刚刚输入的数据写出来,即在屏幕上面打印出来。
运行结果如下: