Linux —— 基础IO — 文件描述符 + 重定向

目录

[4.5 文件描述符 fd](#4.5 文件描述符 fd)

[4.5.1 file对象和进程间的关系:](#4.5.1 file对象和进程间的关系:)

[4.5.2 文件描述符的分配规则](#4.5.2 文件描述符的分配规则)

[4.5.3 重定向](#4.5.3 重定向)

[4.5.3.1 以追加方式打开:](#4.5.3.1 以追加方式打开:)

[4.5.3.2 以读方式打开:](#4.5.3.2 以读方式打开:)

[4.5.4 使用 dup2 系统调用](#4.5.4 使用 dup2 系统调用)

[4.5.4.1 所以第二个重定向的版本如下:](#4.5.4.1 所以第二个重定向的版本如下:)

[4.5.4.2 追加重定向的实现:](#4.5.4.2 追加重定向的实现:)

问题1:

​编辑

问题2:

[5. 给我们历史所写的 minishell 添加 重定向功能!!!](#5. 给我们历史所写的 minishell 添加 重定向功能!!!)

[6. mini shell完整代码](#6. mini shell完整代码)


4.5 文件描述符 fd

文件描述符的本质是:进程的文件描述符表的下标

运行结果:

操作系统内只认文件描述符,所以C语言打开文件,访问文件,所对应的FILE*内部,必定封装了文件描述符,0,1,2被stdin,stdout,stderr封装了。

一个进程打开文件时的struct file,也就是每个进程在打开的时候,都会在内核里创建一个struct file,上层的语言的文件没有那么重要,在系统层面上识别一个文件只认文件描述符:fd。

4.5.1 file对象和进程间的关系:

4.5.2 文件描述符的分配规则

文件描述符的分配规则:在files_struct数组当中,找到当前没有被使用的最小的一个下标,作为新的文件描述符。

运行结果(符合预期,因为0,1,2被占用):

将0号关闭掉,不再指向对应的stdin了,此时表示0下标就可以使用了。

运行结果:(怎么什么也看不到??)

上面的验证至少证实了本来应该像显示器准输出上打印的,在转而经过将1号标准输出关闭,紧挨着创建一个新文件,就可以直接让printf打印到指定的文件中,这个工作就叫做重定向

4.5.3 重定向

用open()打开文件,close()关闭文件的方式以此看到输出重定向和追加重定向的效果。

重定向的本质:

4.5.3.1 以追加方式打开:
4.5.3.2 以读方式打开:

此时读文件的时候就不阻塞了,因为读的时候文件中是有内容的。这个叫做输入重定向。

所以,所谓的重定向就是改0,1,2所对应的底层指向。但是每次都要进行close,此方式不是很好。

4.5.4 使用 dup2 系统调用

4.5.4.1 所以第二个重定向的版本如下:
4.5.4.2 追加重定向的实现:

那么3号原本的指向的内容还在吗?

这个结果就说明了,当我们做重定向之后,3号能够正常使用,1号也能够正常使用,两个都可以向同一个文件写,说明在做重定向时,3号是没有被关的。1号是会被系统自动关掉的。

问题1:

所以说子进程的操作是不会影响父进程的,以下是验证的代码:

运行结果:

所以第一个问题回答完毕:

问题2:

所以回答第二个问题:

用代码来验证:

5. 给我们历史所写的 minishell 添加 重定向功能!!!

重定向操作:

运行结果:

进入到我们自己写的minishell中,进行重定向操作没有没问题。

追加重定向也没问题:

照样也能输入重定向:

6. mini shell完整代码

minishell的完整代码的链接

相关推荐
计算机安禾2 小时前
【Linux从入门到精通】第14篇:Linux引导流程浅析——从按下电源到登录界面
linux·服务器·人工智能·面试·知识图谱
YaBingSec2 小时前
玄机靶场-第三届-长城杯-初赛-SnakeBackdoor WP
java·运维·笔记·tomcat·ssh
雕刻刀2 小时前
服务器模拟断网
linux·服务器·前端
北冥有羽Victoria2 小时前
Django Auth组件完整版教程:从原理到项目落地
大数据·服务器·数据库·后端·python·django·sqlite
ZKNOW甄知科技2 小时前
燕千云ITR深度解析:大型企业如何建立服务价值流?
运维·人工智能·后端·科技·安全·自动化·用户运营
huizhixue-IT2 小时前
华为职业认证新版全景图及重认证规则变更预通知-5月7日开始生效!Datacom和 Security支持跨技术方向的重认证!
运维·服务器
小樱花的樱花2 小时前
Linux文件系统的类型和结构
linux·运维·服务器
手揽回忆怎么睡2 小时前
低负载构建版 Docker/WSL 配置,把宿主机卡顿压到最低
运维·docker·容器
zhangfeng11334 小时前
多台服务器同时训练llamfactory 大语言模型 国家超算中心 Slurm 是目前全球最主流的开源、高性能计算(HPC)集群资源管理与作业调度系统
服务器·语言模型·开源