2010-11-22 40 views
3

我有一個程序,必須使用mmf來將ppm圖像映射到內存,然後,每個孩子將不得不按將mmf反轉。它說:「MMF版本首先必須創建圖像的副本(並將其重命名爲destiny文件名),然後對該副本執行反轉。」信號也是按照正確的順序排列的。帶父親和子女進程的內存映射文件的問題

由此,我已經編碼,它給了我正確的輸出,但發生這種情況:S。我不明白爲什麼,但它顯然不是正確的:

(...) 
Inverting row... 
Done || 
Inverting row... 
Done || 
Cleaning up... 
Closing file pointers. 
*** glibc detected *** ./MMF_inverter: double free or corruption (!prev): 0x093a0170 *** 
======= Backtrace: ========= 
/lib/tls/i686/cmov/libc.so.6(+0x6b591)[0x28e591] 
/lib/tls/i686/cmov/libc.so.6(+0x6cde8)[0x28fde8] 
/lib/tls/i686/cmov/libc.so.6(cfree+0x6d)[0x292ecd] 
/lib/tls/i686/cmov/libc.so.6(fclose+0x14a)[0x27eaaa] 
./MMF_inverter[0x80497d5] 
/lib/tls/i686/cmov/libc.so.6(__libc_start_main+0xe6)[0x239bd6] 
./MMF_inverter[0x8048d01] 
======= Memory map: ======== 
00110000-00125000 r-xp 00000000 08:05 1569987 /lib/tls/i686/cmov/libpthread-2.11.1.so 
00125000-00126000 r--p 00014000 08:05 1569987 /lib/tls/i686/cmov/libpthread-2.11.1.so 
00126000-00127000 rw-p 00015000 08:05 1569987 /lib/tls/i686/cmov/libpthread-2.11.1.so 
00127000-00129000 rw-p 00000000 00:00 0 
00129000-00146000 r-xp 00000000 08:05 1439060 /lib/libgcc_s.so.1 
00146000-00147000 r--p 0001c000 08:05 1439060 /lib/libgcc_s.so.1 
00147000-00148000 rw-p 0001d000 08:05 1439060 /lib/libgcc_s.so.1 
00223000-00376000 r-xp 00000000 08:05 1569962 /lib/tls/i686/cmov/libc-2.11.1.so 
00376000-00377000 ---p 00153000 08:05 1569962 /lib/tls/i686/cmov/libc-2.11.1.so 
00377000-00379000 r--p 00153000 08:05 1569962 /lib/tls/i686/cmov/libc-2.11.1.so 
00379000-0037a000 rw-p 00155000 08:05 1569962 /lib/tls/i686/cmov/libc-2.11.1.so 
0037a000-0037d000 rw-p 00000000 00:00 0 
00459000-0045a000 r-xp 00000000 00:00 0   [vdso] 
00471000-0048c000 r-xp 00000000 08:05 1440096 /lib/ld-2.11.1.so 
0048c000-0048d000 r--p 0001a000 08:05 1440096 /lib/ld-2.11.1.so 
0048d000-0048e000 rw-p 0001b000 08:05 1440096 /lib/ld-2.11.1.so 
00905000-0090c000 r-xp 00000000 08:05 1569989 /lib/tls/i686/cmov/librt-2.11.1.so 
0090c000-0090d000 r--p 00006000 08:05 1569989 /lib/tls/i686/cmov/librt-2.11.1.so 
0090d000-0090e000 rw-p 00007000 08:05 1569989 /lib/tls/i686/cmov/librt-2.11.1.so 
08048000-0804b000 r-xp 00000000 08:05 1458241 /home/neverMind/Desktop/SO-TP2/MMF/MMF_inverter 
0804b000-0804c000 r--p 00002000 08:05 1458241 /home/neverMind/Desktop/SO-TP2/MMF/MMF_inverter 
0804c000-0804d000 rw-p 00003000 08:05 1458241 /home/neverMind/Desktop/SO-TP2/MMF/MMF_inverter 
093a0000-093c1000 rw-p 00000000 00:00 0   [heap] 
b7700000-b7721000 rw-p 00000000 00:00 0 
b7721000-b7800000 ---p 00000000 00:00 0 
b781c000-b7855000 rw-s 00000000 08:05 1458172 /home/neverMind/Desktop/SO-TP2/MMF/out.ppm 
b7855000-b7857000 rw-p 00000000 00:00 0 
b7862000-b7863000 rw-s 00000000 00:04 52069041 /SYSV00000000 (deleted)Aborted 

下面是代碼(如運行./invert input_filename.ppm output_filename.ppm)它必須是PPM:
main
functions c file
header file
makefile

你可以用這個測試,例如:ppm image with p6 header

我只在主進程中映射文件,然後生成子文件並使每個子文件在該映射文件上反轉一行。它是否正確?

+0

它看起來你以某種方式損壞內存,使用valgrind來搜索錯誤。 – Drakosha 2010-11-22 05:40:31

回答

1

其中,您正在關閉文件句柄兩次。按照Drakosha的建議,在valgrind下運行你的程序。

+0

你建議我使用哪些標誌?因爲我已經嘗試了一些......並且有一個信息looooooot。我很新鮮啊,對不起。我現在手頭沒有C編譯器。但我看到了兩個人。我錯過了它。它總是更好地顯示某人你的代碼,我猜 – neverMind 2010-11-22 22:26:37

+0

你會看到大部分的callstack來自雙重fclose()錯誤。修復並重新運行,你會看到很少的輸出。迭代,直到沒有更多的錯誤。 – ninjalj 2010-11-22 22:30:56

+0

@neverMind:實際上,我沒有看你的代碼。 'valgrind'告訴我雙免費錯誤在哪裏。 – ninjalj 2010-11-22 22:32:55