2017-04-25 170 views
1

我發現某些程序在內存映射和其他診斷信息在崩潰時會打印到終端,即使我將文件描述符1和2(分別爲標準輸出和錯誤)重定向到文件。如何將診斷信息重定向到文件?重定向崩潰輸出

例如,該C++程序:

#include <iostream> 
#include <assert.h> 
#include <string> 

int main(){ 
    using namespace std; 
    cout<<"foo"<<endl; 
    cerr<<"bar"<<endl; 
    string s; 
    s = "asdf"; 
    delete &s; 
} 

編譯後,它可以運行,重定向 「所有」 輸出(g++ foo.cpp && ./a.out > /dev/null 2>&1),但仍以下內容打印到終端:

======*** Error in `./a.out': double free or corruption (out): 0x00007ffe389313d0 *** 
======= Backtrace: ========= 
/usr/lib/libc.so.6(+0x722ab)[0x7fc7c053f2ab] 
/usr/lib/libc.so.6(+0x7890e)[0x7fc7c054590e] 
/usr/lib/libc.so.6(+0x7911e)[0x7fc7c054611e] 
./a.out[0x400b41] 
/usr/lib/libc.so.6(__libc_start_main+0xf1)[0x7fc7c04ed511] 
./a.out[0x4009fa] 
= Memory map: ======== 
00400000-00401000 r-xp 00000000 00:27 531373        /tmp/a.out 
00601000-00602000 r--p 00001000 00:27 531373        /tmp/a.out 
00602000-00603000 rw-p 00002000 00:27 531373        /tmp/a.out 
01f1d000-01f4f000 rw-p 00000000 00:00 0         [heap] 
7fc7bc000000-7fc7bc021000 rw-p 00000000 00:00 0 
7fc7bc021000-7fc7c0000000 ---p 00000000 00:00 0 
7fc7c04cd000-7fc7c0668000 r-xp 00000000 08:09 142916      /usr/lib/libc-2.25.so 
7fc7c0668000-7fc7c0867000 ---p 0019b000 08:09 142916      /usr/lib/libc-2.25.so 
7fc7c0867000-7fc7c086b000 r--p 0019a000 08:09 142916      /usr/lib/libc-2.25.so 
7fc7c086b000-7fc7c086d000 rw-p 0019e000 08:09 142916      /usr/lib/libc-2.25.so 
7fc7c086d000-7fc7c0871000 rw-p 00000000 00:00 0 
7fc7c0871000-7fc7c0887000 r-xp 00000000 08:09 144514      /usr/lib/libgcc_s.so.1 
7fc7c0887000-7fc7c0a86000 ---p 00016000 08:09 144514      /usr/lib/libgcc_s.so.1 
7fc7c0a86000-7fc7c0a87000 r--p 00015000 08:09 144514      /usr/lib/libgcc_s.so.1 
7fc7c0a87000-7fc7c0a88000 rw-p 00016000 08:09 144514      /usr/lib/libgcc_s.so.1 
7fc7c0a88000-7fc7c0b9a000 r-xp 00000000 08:09 131998      /usr/lib/libm-2.25.so 
7fc7c0b9a000-7fc7c0d99000 ---p 00112000 08:09 131998      /usr/lib/libm-2.25.so 
7fc7c0d99000-7fc7c0d9a000 r--p 00111000 08:09 131998      /usr/lib/libm-2.25.so 
7fc7c0d9a000-7fc7c0d9b000 rw-p 00112000 08:09 131998      /usr/lib/libm-2.25.so 
7fc7c0d9b000-7fc7c0f13000 r-xp 00000000 08:09 141919      /usr/lib/libstdc++.so.6.0.22 
7fc7c0f13000-7fc7c1113000 ---p 00178000 08:09 141919      /usr/lib/libstdc++.so.6.0.22 
7fc7c1113000-7fc7c111d000 r--p 00178000 08:09 141919      /usr/lib/libstdc++.so.6.0.22 
7fc7c111d000-7fc7c111f000 rw-p 00182000 08:09 141919      /usr/lib/libstdc++.so.6.0.22 
7fc7c111f000-7fc7c1123000 rw-p 00000000 00:00 0 
7fc7c1123000-7fc7c1146000 r-xp 00000000 08:09 142957      /usr/lib/ld-2.25.so 
7fc7c1318000-7fc7c131e000 rw-p 00000000 00:00 0 
7fc7c1344000-7fc7c1345000 rw-p 00000000 00:00 0 
7fc7c1345000-7fc7c1346000 r--p 00022000 08:09 142957      /usr/lib/ld-2.25.so 
7fc7c1346000-7fc7c1347000 rw-p 00023000 08:09 142957      /usr/lib/ld-2.25.so 
7fc7c1347000-7fc7c1348000 rw-p 00000000 00:00 0 
7ffe38911000-7ffe38932000 rw-p 00000000 00:00 0       [stack] 
7ffe38945000-7ffe38947000 r--p 00000000 00:00 0       [vvar] 
7ffe38947000-7ffe38949000 r-xp 00000000 00:00 0       [vdso] 
ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0     [vsyscall] 
Aborted (core dumped) 

回答

0

要將輸出從/dev/tty恢復爲您可以執行的文件:

script -q -c 'g++ foo.cpp && ./a.out' /dev/null > /tmp/bla.txt 

這裏採取 - How to redirect a program that writes to tty?

+0

該命令的'g ++ foo.cpp'部分不會生成輸出,並且與我的主要問題無關。即。即使是你建議的命令'./a.out>/dev/null 2>&1'也會生成輸出到終端。我猜g ++會做一些相當的'回聲錯誤!崩潰! >/dev/tty'來繞過所有重定向;我想知道是否有可能將輸出記錄到文件中。 – Einhaender

+0

好點。我不確定你可以重定向'/ dev/tty'輸出 - 但我正在研究它。 –

+0

嗨@Einhaender - 希望這個編輯能夠回答你的問題。這對我來說是一個快速測試。 –