段错误更新 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);

获取指针的值。