【问题标题】:Passing pointer to array of struct将指针传递给结构数组
【发布时间】:2012-04-21 01:01:34
【问题描述】:

我正在尝试将指针传递给结构数组。这段代码应该创建一个结构数组,写入结构中的变量,然后将它们打印出来(有效)。然后我想将该结构数组的指针传递给另一个函数并打印出struts数组。

#define PORT_NUMBER 5100
#define MAX_CLIENTS 5

#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>
#include <string.h>
#include <pthread.h>

typedef struct thread_args
 {
    int client_number;
    int connected;
    char client_name[1024];
} client;

void pass_func(client* clients[])

int main()
{
  struct thread_args clients[MAX_CLIENTS];
  int i;

  for(i =0; i < MAX_CLIENTS; i++)
  {
  clients[i].client_number=i;
  strcpy(clients[i].client_name, "BOBBY");
  }

    for(i =0; i < MAX_CLIENTS; i++)
  {
     printf("%d | %s\n", clients[i].client_number=i, clients[i].client_name);
  }

  printf("\n\n");
  pass_func(&clients);
}

void pass_func(client* clients[])
{
  int i;
  for(i =0; i < MAX_CLIENTS; i++)
  {
     printf("%d | %s\n", clients[i]->client_number=i, clients[i]->client_name);
  }
}

这是输出:

$ gcc TEST.c -lpthread -o TEST.out
TEST.c: In function ‘main’:
TEST.c:41:3: warning: passing argument 1 of ‘pass_func’ from incompatible pointer type [enabled by default]
TEST.c:22:6: note: expected ‘struct thread_args **’ but argument is of type ‘struct thread_args (*)[5]’

$ ./TEST.out 
0 | BOBBY
1 | BOBBY
2 | BOBBY
3 | BOBBY
4 | BOBBY


Segmentation fault

我已经进行了大约一个小时的研究,但无法弄清楚为什么这不起作用。我发现的大多数示例都是针对 C++ 的,但不是针对 C 的。(是的,我知道我包含的许多头文件对于此代码来说不是必需的;这只是我原始代码的一部分。)

【问题讨论】:

  • pass_func(&clients[0])怎么样
  • @TJD - 这给了我同样的行为。

标签: c arrays struct


【解决方案1】:

pass_func 需要一个指向 client 的指针数组

void pass_func(client* clients[]);

但你通过了它

pass_func(&clients);

指向clients 数组的指针。所以clientclients[i] 被解释为pass_func 中指向client 的指针,但是位模式当然不是指向client 的有效指针,因此您正在尝试访问您不应该访问的内存t 并得到一个段错误。

要么传递一个指针数组,要么声明pass_func

void pass_func(client *clients);

(然后传递 pass_func(clients) 而不在 main 中使用地址运算符)。

不过,您的编译器会警告您传递不兼容的指针类型。

【讨论】:

  • 它确实发出了警告:“TEST.c:41:3: 警告:从不兼容的指针类型传递‘pass_func’的参数 1”
  • 哦,对了。完全错过了。提出了一个问题,为什么人们不注意编译器警告。
  • 我同意,它们非常有用。 (尽管如果您没有太多经验,尤其是对于 GCC,警告可能相当深奥。)
  • 我确实注意到了警告,因此我包含了 gcc 输出,但我无法理解我忽略了什么。我最初尝试不使用 [] 传递 - 这是我认为应该是正确的,但是我一直忽略我正在传递地址的地址(所谓的)。谢谢。
  • @faction918 啊,试图通过暂时忽略它来弄清楚警告的含义是一种合理的策略。但是,不一定是最好的,因为它通常只会导致段错误或工作代码。你也可以在这里问“这个警告对这段代码意味着什么:...”,这应该会给你一个很好的解释。
【解决方案2】:
void pass_func(client* clients[])
{
  int i;
  for(i =0; i < MAX_CLIENTS; i++)
  {
     printf("%d | %s\n", (*clients)[i].client_number=i, (*clients)[i].client_name);
  }
}

这样就好了。

【讨论】:

    【解决方案3】:

    您需要正确掌握基础知识...

    首先需要了解数组是如何传递给函数的: 最好通过this

    【讨论】:

    • 链接已损坏。我正在尝试取消引用指向 2 个嵌套结构的指针。主结构有一个指向另一个结构的指针。 *((uint8_t)th0-&gt;(*(tsk+0))-&gt;args_cnts) = 0; 其中tsk 是指向多个相同类型对象的指针,但不知道如何正确取消引用。
    猜你喜欢
    • 2021-11-02
    • 2019-05-03
    • 2020-05-15
    • 1970-01-01
    • 2015-07-18
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多