段错误更新 c 中的 int 指针
Segfault updating an int pointer in c
我在使用测试程序时遇到了一些问题。如果我尝试取消引用指针以更新其值,则会导致段错误。
这是被调用的函数:
// Extracts a message from the community mailbox
void mbox_withdraw(struct mbox *mb, char *msg, int *len)
{
// Locks the semaphore
sem_wait(lock);
// If message node is null, there is no message, just return
if (mb->msg != NULL)
{
int var = strlen((mb->msg)->message);
len = &var;
strncpy(msg, (mb->msg)->message, len + 1);
// If there is only one message node
if ((mb->msg)->next == NULL)
{
(mb->msg)->message = NULL;
free((mb->msg)->message);
mb->msg = NULL;
free(mb->msg);
}
// There are more than one message, just take the first one
else
{
struct messageNode *temp = mb->msg;
mb->msg = (mb->msg)->next;
temp->message = NULL;
free(temp->message);
temp->next = NULL;
free(temp);
}
}
// Unlocks the semaphore
sem_signal(lock);
}
这是调用函数:
int main(void) {
t_init();
mbox_create(&mb);
t_create(producer, 1, 1);
t_create(producer, 2, 1);
t_create(consumer, 3, 1);
t_yield();
int len;
char mesg[1024];
mbox_withdraw(mb, mesg, &len); // should print a warning about the mailbox not having any messages
mbox_destroy(&mb);
t_shutdown();
printf("Done with mailbox test...\n");
fflush(stdout);
return 0;
}
如果我使用:
int var = strlen((mb->msg)->message);
len = &var;
没有段错误,但当然这不是更新值的正确方法。如果我使用:
int var = strlen((mb->msg)->message);
*len = var;
这是我第一次 post 在这个网站上,所以如果这个 post 看起来很尴尬,请原谅。
未经编译测试,仅使用我的phone。我反应更多的是在strncpy调用下。如果使用带有 -Wall 标志的 gcc 应该给出警告
len = &var;
strncpy(msg, (mb->msg)->message, len + 1);
进入
*len = var;
strncpy(msg, (mb->msg)->message, *len + 1);
或者
*len = var;
strcpy(msg, (mb->msg)->message);
我认为段错误不是由您指定的行产生的。如果您使用 gcc
,最好使用 gdb
或 运行 以及内存模拟(如 valgrind
)进行调试。然后你会看到哪一行是段错误。
如果len
设置不当,后果自负。我想你删除了一些行,但是对于所述示例 len
没有意义,因为它只使用了一次,你可以在这里写:
strncpy(msg, (mb->msg)->message, var + 1);
在函数中,len是一个指针。你在这里做什么:
int var = strlen((mb->msg)->message);
len = &var;
strncpy(msg, (mb->msg)->message, len + 1);
正在将 var 的地址分配给 len 指针(例如,它可以是 0x12345678),然后使用指针(包含 0x12345678)作为值(尝试从(mb-)复制 0x12345678+1 数据>msg)->message to msg), 导致段错误。
第二种方式是对的,将var值赋给len指针值(不是地址),但是接下来你必须做:
strncpy(msg, (mb->msg)->message, *len + 1);
获取指针的值。
我在使用测试程序时遇到了一些问题。如果我尝试取消引用指针以更新其值,则会导致段错误。
这是被调用的函数:
// Extracts a message from the community mailbox
void mbox_withdraw(struct mbox *mb, char *msg, int *len)
{
// Locks the semaphore
sem_wait(lock);
// If message node is null, there is no message, just return
if (mb->msg != NULL)
{
int var = strlen((mb->msg)->message);
len = &var;
strncpy(msg, (mb->msg)->message, len + 1);
// If there is only one message node
if ((mb->msg)->next == NULL)
{
(mb->msg)->message = NULL;
free((mb->msg)->message);
mb->msg = NULL;
free(mb->msg);
}
// There are more than one message, just take the first one
else
{
struct messageNode *temp = mb->msg;
mb->msg = (mb->msg)->next;
temp->message = NULL;
free(temp->message);
temp->next = NULL;
free(temp);
}
}
// Unlocks the semaphore
sem_signal(lock);
}
这是调用函数:
int main(void) {
t_init();
mbox_create(&mb);
t_create(producer, 1, 1);
t_create(producer, 2, 1);
t_create(consumer, 3, 1);
t_yield();
int len;
char mesg[1024];
mbox_withdraw(mb, mesg, &len); // should print a warning about the mailbox not having any messages
mbox_destroy(&mb);
t_shutdown();
printf("Done with mailbox test...\n");
fflush(stdout);
return 0;
}
如果我使用:
int var = strlen((mb->msg)->message);
len = &var;
没有段错误,但当然这不是更新值的正确方法。如果我使用:
int var = strlen((mb->msg)->message);
*len = var;
这是我第一次 post 在这个网站上,所以如果这个 post 看起来很尴尬,请原谅。
未经编译测试,仅使用我的phone。我反应更多的是在strncpy调用下。如果使用带有 -Wall 标志的 gcc 应该给出警告
len = &var;
strncpy(msg, (mb->msg)->message, len + 1);
进入
*len = var;
strncpy(msg, (mb->msg)->message, *len + 1);
或者
*len = var;
strcpy(msg, (mb->msg)->message);
我认为段错误不是由您指定的行产生的。如果您使用 gcc
,最好使用 gdb
或 运行 以及内存模拟(如 valgrind
)进行调试。然后你会看到哪一行是段错误。
如果len
设置不当,后果自负。我想你删除了一些行,但是对于所述示例 len
没有意义,因为它只使用了一次,你可以在这里写:
strncpy(msg, (mb->msg)->message, var + 1);
在函数中,len是一个指针。你在这里做什么:
int var = strlen((mb->msg)->message);
len = &var;
strncpy(msg, (mb->msg)->message, len + 1);
正在将 var 的地址分配给 len 指针(例如,它可以是 0x12345678),然后使用指针(包含 0x12345678)作为值(尝试从(mb-)复制 0x12345678+1 数据>msg)->message to msg), 导致段错误。
第二种方式是对的,将var值赋给len指针值(不是地址),但是接下来你必须做:
strncpy(msg, (mb->msg)->message, *len + 1);
获取指针的值。