zl程序教程

您现在的位置是:首页 >  系统

当前栏目

将Linux下编译的warning警告信息输出到文件中[整理笔记]

Linux文件笔记输出 信息 编译 整理 警告
2023-09-27 14:29:31 时间
Linux中,脚本语言环境中,即你用make xxx即其他一些普通linux命令,比如ls,find等,不同的数字,代表不同的含义: 数字 含义 标准叫法0 标准输入  stdin = standard input1 标准输出  stdout = standard output2 标准错误输出  stderr = standard error而系统默认的stdin,stdout,stderr,都是屏幕,所以,当你执行命令,比如make,后,所输出的信息,都是可以在屏幕上看到的。

Linux中,脚本语言环境中,即你用make xxx即其他一些普通linux命令,比如ls,find等,不同的数字,代表不同的含义: 
数字 含义 标准叫法
0 标准输入  stdin = standard input
1 标准输出  stdout = standard output
2 标准错误输出  stderr = standard error

而系统默认的stdin,stdout,stderr,都是屏幕,所以,当你执行命令,比如make,后,所输出的信息,都是可以在屏幕上看到的。
所以,想要将对应信息输出到某个文件中,就用对应的数字加上重定向符号 ,实现将这些信息,重新定向到对应的文件中,即可。
(上面这两句,也是之前太多的人来解释,但是没有说明白的地方。)
下面以make命令为例来说明,如何把对应的信息,输出到对应的文件中:

1.想要把make输出的全部信息,输出到某个文件中,最常见的办法就是:
make xxx   build_output.txt
此时默认情况是没有改变2=stderr的输出方式,还是屏幕,所以,如果有错误信息,还是可以在屏幕上看到的。
2.只需要把make输出中的错误(及警告)信息输出到文件中ing,可以用:
make xxx 2  build_output.txt
相应地,由于1=stdout没有变,还是屏幕,所以,那些命令执行时候输出的正常信息,还是会输出到屏幕上,你还是可以在屏幕上看到的。
3.只需要把make输出中的正常(非错误,非警告)的信息输出到文件中,可以用:
make xxx 1  build_output.txt
相应地,由于2=stderr没有变,还是屏幕,所以,那些命令执行时候输出的错误信息,还是会输出到屏幕上,你还是可以在屏幕上看到的。
4.想要把正常输出信息和错误信息输出到分别的文件中,可以用:
make xxx 1  build_output_normal.txt 2 build_output_error.txt
即联合使用了1和2,正常信息和错误信息,都输出到对应文件中了。
5. 所有的信息都输出到同一个文件中:
make xxx   build_output_all.txt 2 1
其中的2 1表示错误信息输出到 1中,而 1,指的是前面的那个文件:build_output_all.txt 。
注意:上面所有的1,2等数字,后面紧跟着大于号 ,中间不能有空格
具体的使用方法: 在编译修改好的UBOOT时,个人喜欢自己建个小shell,这样每次不用敲很多命令,就能搞定了。 uboot的shell如下: #!/bin/sh
echo "    uboot creating......"

echo "distclean ..."
    make distclean CROSS_COMPILE=arm-none-linux-gnueabi-
echo "make at91sam9260ek_config ..."
    make at91sam9260ek_config CROSS_COMPILE=arm-none-linux-gnueabi- 2 warning.txt
echo "make all..."
    make all CROSS_COMPILE=arm-none-linux-gnueabi- 2 warning.txt
echo "copy uboot.bin to /opt/uboot_bin!"
    cp u-boot.bin /mnt/hgfs/share/uboot_bin/
echo "make OK!"
解释:使用的板子是9260, 以下语句就将编译过程的中产生的警告信息打印到文件warning.txt中了 make at91sam9260ek_config CROSS_COMPILE=arm-none-linux-gnueabi- 2 warning.txt make all CROSS_COMPILE=arm-none-linux-gnueabi- 2 warning.txt
Android C++系列:Linux文件IO操作(二) 注意这个读写位置和使用C标准I/O库时的读写位置有可能不同,这个读写 位置是记在内核中的,而使用C标准I/O库时的读写位置是用户空间I/O缓冲区中的位置。比如用fgetc读一个字节,fgetc有可能从内核中预读1024个字节到I/O缓冲区中,再返回第一 个字节,这时该文件在内核中记录的读写位置是1024,而在FILE结构体中记录的读写位置是 1。
Android C++系列:Linux文件IO操作(一) 事实上Unbuffered I/O这个名词是有些误导的,虽然write系统调用位于C标准库I/O缓 冲区的底层,但在write的底层也可以分配一个内核I/O缓冲区,所以write也不一定是直接 写到文件的,也可能写到内核I/O缓冲区中,至于究竟写到了文件中还是内核缓冲区中对于 进程来说是没有差别的,如果进程A和进程B打开同一文件,进程A写到内核I/O缓冲区中的数 据从进程B也能读到,而C标准库的I/O缓冲区则不具有这一特性(想一想为什么)