八、make编译输出重定向
4、编译输出重定向
将 make 命令的标准输出(stdout)和标准错误输出(stderr)重定向到文件,以便于查看编译日志,快速分析定位问题。
1、重定向到同一个文件
语法:
make > output.log 2>&1
>:将标准输出(stdout)重定向到output.log文件。2>&1:将标准错误输出、标准输出 输出到output.log文件中。
例子:
希望将编译过程中所有的信息(包括错误信息)都保存到一个日志文件中。
make > build_output.log 2>&1
在这个例子中,build_output.log 文件将包含所有标准输出和标准错误输出。无论是编译成功的消息,还是错误信息,都会被保存在同一个文件中。
输出示例:
Compiling file1.c...
Compiling file2.c...
gcc: error: file3.c: No such file or directory
make: *** [Makefile:15: file3.o] Error 1
2、分别重定向到不同的文件
语法:
make > output.log 2> error.log
>:将标准输出重定向到output.log文件。2>:将标准错误输出重定向到error.log文件。
3、输出追加文件不覆盖文件
默认情况下,> 会覆盖文件的内容。如果希望将新的输出追加到现有文件中,而不是覆盖原有内容,可以使用 >> 来追加。
语法:
make >> output.log 2>&1
>>:将标准输出追加到output.log文件中。2>&1:将标准错误输出也追加到output.log文件中。
例子:
假设执行了多次 make 命令,并希望将每次的输出都追加到一个文件中,以便查看所有的构建日志。可以使用以下命令:
make >> build_output.log 2>&1
这样,每次执行 make 时,它的输出都会追加到 build_output.log 文件中,而不是覆盖之前的内容。
输出示例:
假设第一次执行时文件为空,第一次执行的输出:
Compiling file1.c...
Compiling file2.c...
第二次执行时,输出会追加到文件末尾:
Compiling file3.c...
Compiling file4.c...
4、同时输出到终端和文件
如果希望将 make 命令的输出同时显示在终端上,并保存到文件中,可以使用 tee 命令。tee 会读取标准输入并将其内容输出到标准输出和文件中。
语法:
make 2>&1 | tee output.log
2>&1:将标准错误输出(stderr)重定向到标准输出(stdout)。|:将输出通过管道传递给tee命令。tee output.log:将输出写入output.log文件,同时将其显示在终端上。
例子:
在终端看到编译的过程,同时将日志保存到文件中,可以执行以下命令:
make 2>&1 | tee build_output.log
这样做可以在终端中看到 make 命令的输出,并且所有的输出(包括标准输出和标准错误输出)会被写入到 build_output.log 文件中。
输出示例:
Compiling file1.c...
Compiling file2.c...
gcc: error: file3.c: No such file or directory
make: *** [Makefile:15: file3.o] Error 1
并且这些内容也会被保存到 build_output.log 文件中。
5、在 Makefile 中配置日志记录
在 Makefile 中设置将输出重定向到文件,以便每次执行 make 时,自动将日志记录到文件中,如下:
all:
@echo "Building project..." > build.log 2>&1
make >> build.log 2>&1
在这个示例中,make 会先将 Building project... 信息写入 build.log,然后将后续的所有 make 输出(包括错误信息)追加到同一个日志文件中。

浙公网安备 33010602011771号