我在我的程序中遇到了一个奇怪的bug,看起来似乎是malloc()引起了SIGSEGV错误,就我所知道的,这是毫无意义的。我正在使用一个叫做simclist的动态列表库。
这里有一个稍后会被引用的结构体:
typedef struct {
int msgid;
int status;
void* udata;
list_t queue;
} msg_t;
这里是代码:
msg_t* msg = (msg_t*) malloc( sizeof( msg_t ) );
msg->msgid = msgid;
msg->status = MSG_STAT_NEW;
msg->udata = udata;
list_init( &msg->queue );
list_init
是程序失败的地方,下面是 list_init
的代码:
/* list initialization */
int list_init(list_t *restrict l) {
if (l == NULL) return -1;
srandom((unsigned long)time(NULL));
l->numels = 0;
/* head/tail sentinels and mid pointer */
l->head_sentinel = (struct list_entry_s *)malloc(sizeof(struct list_entry_s));
l->tail_sentinel = (struct list_entry_s *)malloc(sizeof(struct list_entry_s));
l->head_sentinel->next = l->tail_sentinel;
l->tail_sentinel->prev = l->head_sentinel;
l->head_sentinel->prev = l->tail_sentinel->next = l->mid = NULL;
l->head_sentinel->data = l->tail_sentinel->data = NULL;
/* iteration attributes */
l->iter_active = 0;
l->iter_pos = 0;
l->iter_curentry = NULL;
/* free-list attributes */
l->spareels = (struct list_entry_s **)malloc(SIMCLIST_MAX_SPARE_ELEMS * sizeof(struct list_entry_s *));
l->spareelsnum = 0;
#ifdef SIMCLIST_WITH_THREADS
l->threadcount = 0;
#endif
list_attributes_setdefaults(l);
assert(list_repOk(l));
assert(list_attrOk(l));
return 0;
}
这行代码
l->spareels = (struct list_entry_s **)malloc(SIMCLIST_MAX_SPARE_ELEMS *
是导致 SIGSEGV 的原因。我正在使用 gdb/nemiver 进行调试,但是一直没有头绪。第一次调用此函数时它可以正常工作,但第二次调用时总是失败。malloc() 如何导致 SIGSEGV?以下是堆栈跟踪信息:
#0 ?? () at :0
#1 malloc () at :0
#2 list_init (l=0x104f290) at src/simclist.c:205
#3 msg_new (msg_switch=0x1050dc0, msgid=8, udata=0x0) at src/msg_switch.c:218
#4 exread (sockfd=8, conn_info=0x104e0e0) at src/zimr-proxy/main.c:504
#5 zfd_select (tv_sec=0) at src/zfildes.c:124
#6 main (argc=3, argv=0x7fffcabe44f8) at src/zimr-proxy/main.c:210
任何帮助或见解都非常感激!
srandom()
。为了避免未来的错误,即使已知list_init()
只会被调用一次,您也应该将种子放在更明显执行一次的地方,比如在main()
的顶部附近。 - RBerteig