文章目录

  • 前言
  • 一、输出重定向
  • 二、输入重定向
  • 三、重定向原理
  • 总结

前言

我们有些时候想要将命令的输出保存起来,而不仅仅是让它输出到显示器上(终端上)。将命令的输出保存再文件中后方便分析输出的内容。重定向也可以是输出也可以是输入。

一、输出重定向

输出重定向:将命令的输出发送的一个文件中,终端输出的内容会被保存到输出文件中

bash shell : >输出的内容会覆盖已有文件的内容bash shell : >> 输出的内容追加到已有的文件中


覆盖重定向:

追加重定向:

二、输入重定向

输入重定向:将文件的内容重定向到命令中

bash shell : <将文件的内容重定向命令中,作为命令的输入bash shell : << 输入不需要文件进行重定向,只需要在命令行中指定用于输入重定向的数据即可

输入重定向:
wc命令用来对数据中的文本进行计数,默认情况下:
文本的行数 文本的单词个数 文本的字节数

内联输入重定向:
必须指定一个文本标记来划分输入数据的开始结尾。任何字符串都可以作为文本标记,单开始和结尾的文本标记必须一致
(1)以EOF作为文本标记

(2)以hi作为文本标记

三、重定向原理

来自于我的这篇文章:Linux fork 写时复制

分离fork和exec的做法在构建Linux shell的时候非常有用,这给了shell在fork之后exec之前运行代码的机会,这些代码可以在运行一个全新的程序前改变环境。
shell也是一个用户程序,它会显示一个提示符,等待用户的输入。
当我们向shell输入一个命令(一个可执行的程序)时,shell就在文件系统中找到这个可执行的程序,通过调用fork()创建新进程,并调用exec系列函数来执行这个可执行的程序,调用wait()等待该命令的完成。子进程执行结束后,shell从wait()返回并再次输出提示符,等待用户的下一条命令。

那么现在我们通过一个小例程来体会一下fork + exec组合分离的强大功能:

#include #include #include #include #include #include #include int main(){int ret = fork();if(ret == 0){//fork之后,exec执行之前,来改变一些子进程运行的环境//关闭 STDOUT_FILENO : 标准输出,对应的文件描述符为 1close(STDOUT_FILENO);//打开file.txt文件,这样 wc 的执行结果写入file.txt文件中open("./file.txt", O_CREAT | O_WRONLY | O_TRUNC , S_IRWXU);char *my_args[3];my_args[0] = strdup("wc");my_args[1] = strdup("fork_exec.c");my_args[2] = NULL;//执行exec函数,运行一个新shell程序:wc fork_exec.cexecvp(my_args[0], my_args);}else if(ret > 0){wait(NULL);}else{printf("fork error\n");return -1;}return 0;}

从结果可以看出两者运行的结构一致:
wc用来统计指定文件的行数、字数,以及字节数。

shell重定向的原理:当shell调用fork完成子进程的创建后,shell在调用exec()之前先关闭了标准输出,
然后打开文件redirect.txt,这样shell命令wc 的输出结果就被发送到文件redirect.txt中,而不是输出给标准输出,打印在屏幕上。

总结

注意,不管是输出重定向还是输入重定向,命令总是在左边。重定向的符号指向数据的流动方向。