c - 分配结构数组时遇到问题

标签 c

每当我尝试访问结构数据成员时,我的代码就会出现段错误。这必须是因为它没有正确分配。我不知道为什么这不起作用。该结构看起来已正确定义。 malloc 看起来设置正确。我使用正确的格式来访问数据。但是,每当我尝试访问任何内容时,它都会出现段错误。

struct fracBlock {
  struct fracBlock *next ;
  fraction frac ;
} ;

static struct fracBlock *fbp ;

void init_heap(void){ fbp = NULL ; }

fraction *new_frac(void){
  struct fracBlock **tempBlock ;
  struct fracBlock *prev ;
  struct fracBlock *curr ;
  fraction *tempFrac ;
  fraction testFrac ;
  int i ;
//if free list is empty malloc 10 blocks
  if ( fbp == NULL ){
    tempBlock = ( struct fracBlock** )malloc(10*sizeof(struct fracBlock)) ;

  //if no more space left
  if ( tempBlock == NULL ) {
    printf( "\nError: No more memory space left for allocation!\n" ) ;
    exit(1) ;
  }

  tempBlock[0]->next = tempBlock[1] ;
  tempBlock[1]->next = tempBlock[2] ;
  tempBlock[2]->next = tempBlock[3] ;
  tempBlock[3]->next = tempBlock[4] ;
  tempBlock[4]->next = tempBlock[5] ;
  tempBlock[5]->next = tempBlock[6] ;
  tempBlock[6]->next = tempBlock[7] ;
  tempBlock[7]->next = tempBlock[8] ;
  tempBlock[8]->next = NULL ;
  *tempFrac = tempBlock[9]->frac ;

  return tempFrac ;
}

最佳答案

您发布的代码中存在一些严重的错误。

1) 缺少一个

2) tempfrac 是一个未初始化 指针,但您执行 *tempfrac = ... 这是未定义的行为,因此任何事情都可能发生。可能会发生崩溃。也许你忘记了像 tempfrac = malloc(sizeof *tempfrac);

这样的 malloc 内存

3) 即使 tempfrac 是使用 malloc 分配的,行 *tempFrac = tempBlock[9]->frac ; 仍然是错误的,因为 block 9 中的 frac 也未初始化。该代码毫无意义。它试图返回(指向)未初始化值的指针。

4) 双指针的使用是错误的。代码应该更像:

  struct fracBlock *tempBlock ;  // Single *

  if ( fbp == NULL ){
    tempBlock = malloc(10*sizeof *tempBlock) ;

    //if no more space left
    if ( tempBlock == NULL ) {
      printf( "\nError: No more memory space left for allocation!\n" ) ;
      exit(1) ;
    }

    tempBlock[0].next = tempBlock + 1; // or tempBlock[0].next = &tempBlock[1];
    tempBlock[1].next = tempBlock + 2;
    ...

5) 您永远不会更新 fbp 换句话说,您所做的 malloc 是指向函数完成时超出范围的指针。所以你有内存泄漏。您很可能不应该使用局部变量 tempBlock,而是直接对 fbp 进行操作。喜欢:

  if ( fbp == NULL ){
    fbp = malloc(10*sizeof *fbp) ;

    //if no more space left
    if ( fbp == NULL ) {
      printf( "\nError: No more memory space left for allocation!\n" ) ;
      exit(1) ;
    }

    fbp[0].next = fbp + 1;
    fbp[1].next = fbp + 2;
    ...

也就是说,请注意全局变量几乎总是一件坏事。避开它们。

关于c - 分配结构数组时遇到问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56087067/

相关文章:

c - 结构填充可靠性

c - 从命令行读取最后 10 行的程序中出现段错误

android - 我在哪里可以找到 __ioctl?

c - 如何从 C 中的其他函数调用 main()

c - 如何将十六进制 ASCII 值保存到 C 中的数组(缓冲区)?

c - scanf() 将换行符保留在缓冲区中

c - 是否可以创建一个接受 3 个整数并输出奇数/偶数整数而不使用数组的程序?

C、创建一个指向 8 位数组的 32 位指针

c - 绕过 tcp/ip header 的原始套接字

c - 使用数组表示法访问函数内的三重指针