Linux shell之重定向

本文阅读 4 分钟
首页 Linux,系统 正文

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

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

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

img 覆盖重定向: img 追加重定向: img

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

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

输入重定向: wc命令用来对数据中的文本进行计数,默认情况下: 文本的行数 文本的单词个数 文本的字节数 img 内联输入重定向: 必须指定一个文本标记来划分输入数据的开始结尾。任何字符串都可以作为文本标记,单开始和结尾的文本标记必须一致 (1)以EOF作为文本标记 img (2)以hi作为文本标记 img

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

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

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

#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/wait.h>
#include <fcntl.h>
#include <string.h>

int main()
{ 
    int ret = fork();
    if(ret == 0){ 
        //fork之后,exec执行之前,来改变一些子进程运行的环境
        //关闭 STDOUT_FILENO : 标准输出,对应的文件描述符为 1
        close(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.c
        execvp(my_args[0], my_args);
        
    }else if(ret > 0){ 
        wait(NULL);
        
    }else{ 
        printf("fork error\n");
        return -1;
    }

    return 0;
}

从结果可以看出两者运行的结构一致: wc用来统计指定文件的行数、字数,以及字节数。 img shell重定向的原理:当shell调用fork完成子进程的创建后,shell在调用exec()之前先关闭了标准输出, 然后打开文件redirect.txt,这样shell命令wc 的输出结果就被发送到文件redirect.txt中,而不是输出给标准输出,打印在屏幕上。 img

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

本文为互联网自动采集或经作者授权后发布,本文观点不代表立场,若侵权下架请联系我们删帖处理!文章出自:https://blog.csdn.net/weixin_45030965/article/details/125417793
-- 展开阅读全文 --
BUUCTF Web [极客大挑战 2019]Knife
« 上一篇 06-24
安全面试之XSS(跨站脚本攻击)
下一篇 » 07-24

发表评论

成为第一个评论的人

热门文章

标签TAG

最近回复