1

我正在尝试在结构元素上使用 memset,如下所示:

memset( &targs[i]->cs, 0, sizeof( xcpu ) );

但是,这样做会给我一个分段错误。我既不明白为什么会失败,也不明白如何让它发挥作用。在结构的元素上使用 memset 的正确方法是什么,为什么我的方法不起作用?

为目标分配内存的行:

eargs **targs = (eargs **) malloc(p * sizeof(eargs *));

struct element cs (xcpu_context) 和 struct targs (execute_args) 的结构定义:

typedef struct xcpu_context {
  unsigned char *memory;              
  unsigned short regs[X_MAX_REGS];    
  unsigned short pc;                  
  unsigned short state;              
  unsigned short itr;                 
  unsigned short id;                 
  unsigned short num;                 
} xcpu;

typedef struct execute_args {
    int ticks;
    int quantum;
    xcpu cs;
} eargs;
4

2 回答 2

2

您已在该行中分配了一个指针数组

eargs **targs = (eargs **) malloc(p * sizeof(eargs *));

但是您还没有初始化元素本身。因此,此段错误与在结构的字段上正确使用 memset 无关,而是源自使用 uininitialized 内存(假设您在分配指针数组后没有循环来初始化每个 eargs 对象)。

相反,如果你想分配一个动态的peargs 对象数组(我在这里松散地使用术语“对象”),你会写

eargs *args = malloc(p * sizeof(eargs));
if (!args) {
    /* Exit with an error message */
}
memset(&(args[i].cs), 0, sizeof(xcpu));

反而。请注意,这args是一个动态分配的 eargs 对象数组,而不是一个动态分配的指针数组,所以它的类型eargs *而不是eargs **.

于 2012-03-08T00:15:14.683 回答
1

您的内存分配行不会为任何结构分配任何内存,仅用于指向结构的指针。如果要为整个数组分配内存,则需要添加一个循环来为结构本身分配内存:

for (i = 0; i < p; i++)
    targs[i] = malloc(sizeof(eargs));

一旦你真正结构可以操作,你的memset()调用应该没问题。

于 2012-03-08T00:15:57.447 回答