FORTRAN コードの一部の割り当て解除と割り当てに問題があります。特に、この問題は、Web 上のエラー メッセージの検索からのメモリ割り当てに関係していると思います。エラーメッセージは無効なポインターについて述べていますが、プログラムでポインターを使用していません
f ループの反復 # 2 (以下を参照) を完了した後、プログラムがクラッシュするか、ほとんどの場合クラッシュし、フリーズすることもあります。これがバグのポイントであると確信しています。プログラムはこの時点まで実行されます。
表示されていないサブルーチンがありますが、それらは他のシミュレーションの組み合わせで機能するため、問題がないと確信しています。私はプログラム内の他の場所で deallocate と allocate を (成功して) 使用しているので、ここで機能していないことに驚いています。
読みやすくするために、プログラムの一部のみを示しています。特に、私が書いたサブルーチンへの呼び出しを削除しました。プログラマーが問題を解決するのに十分な情報を提供できたことを願っています。そうでない場合は、他に必要な情報を指定してください。喜んで対応させていただきます。さまざまなコンパイラ オプションを使用してプログラムをコンパイルし、いくつかのバグを修正し、警告をすべて削除しました。ただし、この時点では、コンパイラ オプションからはそれ以上の情報は得られません。
allocate(poffvect(1:6))
allocate(phi1out(1:1))
allocate(phi2out(1:1))
allocate(phi1outs1(1:1))
allocate(phi2outs1(1:1))
dummy allocation
allocate(phi1outind(1:1))
allocate(phi2outind(1:1))
allocate(phi1outinds1(1:1))
allocate(phi2outinds1(1:1))
do e = 1, 6
print *,"e", e
do f = 1, 3
print *,"f", f, iteratst1(f), trim(filenumcharimp)
deallocate(phi1outinds1, STAT = AllocateStatus)
if (AllocateStatus /= 0) stop "Error during deallocation of phi1outinds1"
print *, "Allocatestatus of phi1outinds1 is", AllocateStatus
deallocate(phi2outinds1, STAT = AllocateStatus)
print *, "DeAllocatestatus of phi1outinds2 is", AllocateStatus
if (AllocateStatus /= 0) stop "Error during deallocation of phi2outinds1"
print *, "we deallocate f loop ok", iteratst1(f)
allocate(phi1outinds1(1:iteratst1(f)), STAT = AllocateStatus)
if (AllocateStatus /= 0) stop "Error during allocation of phi1outinds1"
allocate(phi2outinds1(1:iteratst1(f)), STAT = AllocateStatus)
if (AllocateStatus /= 0) stop "Error during deallocation of phi1outinds1"
end do
end do
コンパイラ オプション
ifort -free -check -traceback -o adatptmultistage1new.out adatptmultistage1new.f90
出力
e 1
f 1 5000 43
DeAllocatestatus of phi1outinds1 is 0
DeAllocatestatus of phi1outinds2 is 0
we deallocate f loop ok 5000
f loop done 1
f 2 10000 43
Allocatestatus of phi1outinds1 is 0
DeAllocatestatus of phi1outinds2 is 0
we deallocate f loop ok 10000
f loop done 2
f 3 15000 43
Allocatestatus of phi1outinds1 is 0
エラーメッセージ
*** glibc detected *** ./adatptmultistage1new.out: munmap_chunk(): invalid pointer: 0x0000000000d3ddd0 ***
======= Backtrace: =========
/lib/libc.so.6(+0x77806)[0x7f5863b7b806]
. /adatptmultistage1new.out[0x43247c]
. /adatptmultistage1new.out[0x404368]
./adatptmultistage1new.out[0x4031ec]
/lib/libc.so.6(__libc_start_main+0xfd)[0x7f5863b22c4d]
. /adatptmultistage1new.out[0x4030e9]
======= Memory map: ========
00400000-004d4000 r-xp 00000000 08:03 9642201
/home/jgold/smwcv/error_infect/test/surfaces/multistage/adaptonly/adatptmultistage1new.out
006d4000-006dc000 rw-p 000d4000 08:03 9642201
[簡潔にするために、残りのエラー メッセージは表示されません]
7fffb004d000-7fffb00bc000 rw-p 00000000 00:00 0 [stack]
7fffb01d7000-7fffb01d8000 r-xp 00000000 00:00 0 [vdso]
ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0 [vsyscall]
Aborted