同一进程中的两个线程使用存储在共享内存中的 rwlock 对象在 pthreads 压力测试期间遇到崩溃。我花了一段时间试图找到内存损坏或死锁,但到目前为止还没有。这只是一种不太理想的方式来通知我我已经造成了僵局吗?关于调试这个的工具/方法的任何指针?
线程 5“tms_test”收到信号 SIGABRT,已中止。 [切换到线程 0x7ffff28a7700 (LWP 3777)] 0x00007ffff761e428 在 ../sysdeps/unix/sysv/linux/raise.c:54 中的 __GI_raise (sig=sig@entry=6) 54 ../sysdeps/unix/sysv/linux/raise.c:没有这样的文件或目录。 (gdb) BT #0 0x00007ffff761e428 in __GI_raise (sig=sig@entry=6) at ../sysdeps/unix/sysv/linux/raise.c:54 #1 0x00007ffff762002a 在 __GI_abort () at abort.c:89 #2 0x00007ffff76607ea in __libc_message (do_abort=do_abort@entry=1, fmt=fmt@entry=0x7ffff77776cc "%s") at ../sysdeps/posix/libc_fatal.c:175 #3 0x00007ffff766080e in __GI___libc_fatal (message=message@entry=0x7ffff79c4ae0 "The futex facility returned an unexpected error code.") at ../sysdeps/posix/libc_fatal.c:185 #4 0x00007ffff79be7e5 in futex_fatal_error () at ../sysdeps/nptl/futex-internal.h:200 #5 futex_wait (private=, expected=, futex_word=0x7ffff7f670d9) at ../sysdeps/unix/sysv/linux/futex-internal.h:77 #6 futex_wait_simple (private=, expected=, futex_word=0x7ffff7f670d9) at ../sysdeps/nptl/futex-internal.h:135 #7 __pthread_rwlock_wrlock_slow (rwlock=0x7ffff7f670cd) 在 pthread_rwlock_wrlock.c:67 #8 0x00000000004046e3 in _memstat (offset=0x7fffdc0b11a5, func=0x0, lineno=0, size=134, flag=1 '\001') at tms_mem.c:107 #9 0x000000000040703b 在 TmsMemReallocExec (in=0x7fffdc0abb81, size=211, func=0x43f858 "_malloc_thread", lineno=478) at tms_mem.c:390 #10 0x000000000042a008 在 _malloc_thread (arg=0x644c11) at tms_test.c:478 #11 0x000000000041a1d6 in _threadStarter (arg=0x644c51) at tms_mem.c:2384 #12 0x00007ffff79b96ba in start_thread (arg=0x7ffff28a7700) at pthread_create.c:333 #13 0x00007ffff76ef82d 在 ../sysdeps/unix/sysv/linux/x86_64/clone.S:109 中的克隆 () (gdb)