散列期间C中的内存分配错误

时间:2015-03-20 08:21:43

标签: c

我是C编程新手,我试图在我的代码中实现typedef和散列。但是当我尝试分配内存时,我收到了编译错误 -

这是我的header文件

#define MAX1 11
#define MAX2 23

typedef short IP[4];
typedef enum{TRUE = 1,FALSE = 0}boolean;

typedef struct
{
    IP p;
    char *comp_name;
}Element;

typedef struct
{
    Element e;
    boolean deleted; // deleted flag
    boolean empty;
}Cell;
typedef Cell secLevelHashTable[MAX2];

typedef struct secLevelHashTable *FirstLevelHashTable[MAX1];

typedef struct FirstLevelHashTable hashTable;

这是我的main代码 -

#include"hashDef.h"
#include<stdio.h>  
#include<stdlib.h>
void initFirstHTable(hashTable H)
 {
int i,j;
    for(i=0;i<MAX1;i++)
    {
        H. FirstLevelHashTable[i]=(secLevelHashTable *)malloc(sizeof(secLevelHashTable));
        H.FirstLevelHashTable[i]->secLevelHashTable=malloc(sizeof(Cell)*MAX2);
        for(j=0;j<MAX2;j++)
        {
            initSecHTables(H.FirstLevelHashTable[i]->secLevelHashTable[j]);
        }
    }


 }  

 void initSecHTables(Cell *ptr)
 {
    ptr->deleted=0;
    ptr->empty=1;
 }





 int main()
 {
    hashTable h;
    h=malloc(sizeof(FirstLevelHashTable));
    initFirstHTable(h);
    return 0;
 }

这是我得到的错误 -

In function ‘main’:
hashOps.c:79:13: error: storage size of ‘h’ isn’t known
   hashTable h;

1 个答案:

答案 0 :(得分:1)

下面的固定代码。它有很多小问题和一个大问题。

请阅读相关文章:

struct in C: Error storage size of 'params' isn't known - 这将解释&#34;存储空间大小未知&#34;错误;通过说typedef struct FirstLevelHashTable hashTable;你定义了一个未完成的结构,而不是引用现有的类型。

标题文件:

#define MAX1 11
#define MAX2 23

typedef short IP[4];
typedef enum{TRUE = 1,FALSE = 0}boolean;

typedef struct
{
    IP p;
    char *comp_name;
}Element;

typedef struct
{
    Element e;
    boolean deleted; // deleted flag
    boolean empty;
}Cell;

typedef Cell secLevelHashTable[MAX2];
typedef secLevelHashTable* FirstLevelHashTable[MAX1];
typedef FirstLevelHashTable hashTable;

主要代码:

#include"hashDef.h"
#include <stdio.h>
#include <stdlib.h>

void initSecHTables(Cell *ptr)
{
   ptr->deleted=0;
   ptr->empty=1;
}

void initFirstHTable(hashTable H)
{
   int i,j;
   for(i=0;i<MAX1;i++)
   {
       H[i]=(secLevelHashTable *)malloc(sizeof(secLevelHashTable));
       for(j=0;j<MAX2;j++)
       {
           initSecHTables(&((*H[i])[j]));
       }
   }
}

int main()
{
   hashTable h;
   initFirstHTable(h);
   return 0;
}