【Makefile】编译日志之输出重定向符号 >

用法1

bash 复制代码
make all >&  compilelog.txt
make all >  compilelog.txt

这两个编译命令在功能上有一些细微的区别,主要在于标准输出和标准错误的处理方式。

  1. make all >& compilelog.txt

    • 这个命令会将标准输出(stdout)和标准错误(stderr)都重定向到同一个文件 compilelog.txt 中。这意味着所有通过 printfecho 等函数输出的信息以及错误信息都会被写入到 compilelog.txt 文件中。
    • 具体来说,>& 是 Bash 中的一个特殊语法,它将文件描述符 1(标准输出)重定向到文件描述符 2(标准错误),然后再一起重定向到指定的文件。因此,标准输出和标准错误都会合并并写入到同一个文件中。
  2. make all > compilelog.txt

    • 这个命令只会将标准输出(stdout)重定向到 compilelog.txt 文件中,而标准错误(stderr)仍然会在控制台上显示。这意味着只有正常的编译输出会被记录到 compilelog.txt 文件中,而错误信息则会直接显示在终端或控制台上。
    • 具体来说,> 是标准的输出重定向符号,它将标准输出重定向到指定的文件,但不会影响标准错误的输出。

总结

  • make all >& compilelog.txt:标准输出和标准错误都被重定向到 compilelog.txt 文件中。
  • make all > compilelog.txt:只有标准输出被重定向到 compilelog.txt 文件中,标准错误仍然会在控制台上显示。

选择哪种方式取决于你的需求。如果你希望同时记录正常输出和错误信息,可以使用第一个命令;如果你只关心正常输出,可以使用第二个命令。

用法2

bash 复制代码
make -f Makefile 1> 3308_linux.txt 2>&1

这个命令用于在 Linux 或 Unix 系统中编译代码,并将编译过程中的标准输出和标准错误都重定向到一个名为 3308_linux.txt 的文件中。

具体来说:

  • make -f Makefile:调用 make 工具,并指定使用 Makefile 文件来控制编译过程。
  • 1> 3308_linux.txt:将标准输出(文件描述符 1)重定向到 3308_linux.txt 文件中。
  • 2>&1:将标准错误(文件描述符 2)重定向到标准输出(文件描述符 1),这意味着标准错误也会被写入到 3308_linux.txt 文件中。

总结

这个命令会执行以下操作:

  1. 使用指定的 Makefile 文件进行编译。
  2. 将所有正常的编译输出(标准输出)和错误信息(标准错误)都重定向到 3308_linux.txt 文件中。

这样做的好处是,你可以方便地查看和分析编译过程中的所有输出信息,而不需要分别查看标准输出和标准错误。question_type_trigger

用法3

make all >& compilelog.txt 多次调用,下一次编译日志会覆盖上一次吗?

是的,如果你多次调用 make all >& compilelog.txt,每次编译的日志都会覆盖上一次的日志。这是因为重定向操作会将文件内容清空并写入新的输出。

示例

假设你第一次运行:

sh 复制代码
make all >& compilelog.txt

这会将第一次编译的输出和错误信息写入到 compilelog.txt 文件中。

然后你再次运行:

sh 复制代码
make all >& compilelog.txt

这次编译的输出和错误信息会覆盖 compilelog.txt 文件中的内容,之前的记录会被清除。

如何保留所有日志

如果你希望保留每次编译的日志,可以使用追加重定向符号 >> 而不是覆盖重定向符号 >

使用追加重定向
sh 复制代码
make all >> compilelog.txt 2>&1

这样,每次编译的输出和错误信息都会被追加到 compilelog.txt 文件的末尾,而不会覆盖之前的内容。

总结

  • 覆盖模式make all >& compilelog.txt 每次运行时会覆盖 compilelog.txt 文件的内容。
  • 追加模式make all >> compilelog.txt 2>&1 每次运行时会将新的内容追加到 compilelog.txt 文件的末尾,保留之前的内容。question_type_trigger
相关推荐
charlie11451419121 天前
Linux Kernel Programming4
linux·c·makefile·内核开发·内核日志
张飞的猪1 个月前
Makefile文件中,两个$的变量变量$$Xxx 与一个$的变量 $Xxx的区别
makefile
却道天凉_好个秋1 个月前
c++ CMakeLists.txt详解
c++·makefile·cmakelists.txt
vv_a3 个月前
5规则中的命令
makefile
DieSnowK4 个月前
[项目][WebServer][Makefile & Shell]详细讲解
开发语言·c++·http·makefile·shell·项目·webserver
橘子真甜~4 个月前
Linux基础3-基础工具3(make,makefile,gdb详解)
linux·运维·服务器·makefile·make·gbd
zhangzhangkeji4 个月前
make 程序规定的 makefile 文件的书写语法
makefile·make
Betty’s Sweet5 个月前
[Linux]:环境开发工具
linux·git·vim·makefile·gdb·gcc·g++
想想吴5 个月前
15 - make 中的隐式规则概述
makefile·隐式规则