文件描述符实际上就是一个小整数
0 & 1 & 2
·Linux进程默认情况下会有3个缺省打开的文件描述符,分别是标准输入0, 标准输出1, 标准错误2.
·0,1,2对应的物理设备一般是:键盘,显示器,显示器所以输入输出还可以采用如下方式:
文件描述符就是从0开始的小整数。当我们打开文件时,操作系统在内存中要创建相应的数据结构来描述目标文件。于是就有了file结构体。表示一个已经打开的文件对象。而进程执行open系统调用,所以必须让进程和文件关联起来。每个进程都有一个指针*files, 指向一张表files_struct,该表最重要的部分就是包涵一个指针数组,每个元素都是一个指向打开文件的指针!所以,本质上,文件描述符就是该数组的下标。所以,只要拿着文件描述符,就可以找到对应的文件。
文件描述符的分配规则
直接看代码:
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main()
{
int fd = open("bite", O_RDONLY);
if(fd < 0)
{
perror("open"); return 1;
}
printf("fd: %d\n", fd);
close(fd);
return 0;
}
试试关闭0或者2
int main()
{
close(0);
//close(2);
int fd = open("bite", O_RDONLY);
if(fd < 0)
{
perror("open"); return 1;
}
printf("fd: %d\n", fd);
close(fd);
return 0;
}
发现是结果是: fd: 0 或者 fd: 2 可见,文件描述符的分配规则:在files_struct数组当中,找到当前没有被使用的最小的一个下标,作为新的文件描述符。
重定向
那如果关闭1呢?
int main()
{
close(1);
int fd = open("bite", O_WRONLY|O_CREAT, 00644);
if(fd < 0)
{
perror("open"); return 1;
}
printf("fd: %d\n", fd);
fflush(stdout);
close(fd); exit(0);
}
此时,我们发现,本来应该输出到显示器上的内容,输出到了文件 "bite"当中,其中,fd=1。这种现象叫做输出重定向。常见的重定向有:>, >>, <
那重定向的本质是什么呢?