【Linux】文件描述符的理解、重定向原理

17 篇文章 0 订阅
8 篇文章 0 订阅

1. 文件描述符的本质

我们知道,当一个程序在运行时,会挂起一个task_struct结构体,保存着描述该进程的信息。task_struct结构体中保存着*files指针,其指向一个名为files_struct的结构体,files_struct结构体中包含着一个指针数组file*fd_array[],数组的每个元素都是一个指向打开文件的指针。因此本质上,文件描述符就是该数组的下标。 Linux进程默认情况下会有三个缺省打开(默认打开)的文件描述符,分别是标准输入0,标准输出1,标准错误2;0、1、2对应的物理设备一般是键盘、显示器、显示器。
在这里插入图片描述

文件描述符的分配规则,最小分配原则:在指针数组file*fd_array[]当中找到当前没有被使用的最小的一个下标,作为新的文件描述符。

2. 重定向原理

重定向本质上是改变了文件描述符的指向

  1. 方式一: 关闭文件描述符1(关闭标准输出),再创建一个新的文件,此时打开该文件的文件描述符应该为1(最小分配原则),再用printf输出,发现本来应该输出到显示器上的内容,输入到了文件myfile当中,其中fd = 1。这种现象叫做输出重定向。常见的重定向有:>, >>, <
    从指向标准输出重定向到新打开的文件myfile,因此内容输出到了myfile文件中。
close(1);
int fd = open("myfile", O_WRONLY | O_CREAT, 00644);
if(fd < 0)
{
	perror("open");
	return 1;
}
printf("fd: %d\n", fd);
fflush(stdout);//刷新标准输出
close(fd);
  1. 方式二: 使用dup2系统调用接口
int dup2(int oldfd, int newfd);

newfd拷贝oldfd的值,将newfd重定向为oldfd

  • 若调用成功,则关闭newfd,并让newfd指向oldfd
  • oldfd是一个非法的文件描述符,或者不存在的文件描述符,则调用失败,并且没有关闭newfd
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值