gpt4 book ai didi

c - 具有 union 静态和动态字符数组的结构

转载 作者:太空狗 更新时间:2023-10-29 15:41:01 24 4
gpt4 key购买 nike

我正在创建一个动态分配的链表,其中每个项目都有一个数据元素。这些元素中的大多数是固定大小的字符数组,但有些元素的长度可以变化,例如只有 1 或 2 个字符 - 或 1000+ 个字符。

如果我在数据元素内部使用静态和动态字符数组的 union ——它是否总是会占用:

  • 静态的大小还是 malloc 的 malloced 的大小?
  • 静态的大小 + 如果 malloc 是 malloced 的大小?
  • 指向分配的指针的大小还是静态指针的大小?
  • ...(等等)

没有列表的简化示例。这不是我用数据填充它的方式,- 仅作为结构 union 的示例。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

enum meta_type {LIST, STRING};

struct meta {
union {
char clist[128];
char *cstr;
} val;
enum meta_type type;
};

int init_meta(struct meta *meta, enum meta_type type, int size, char *data)
{
if (type == STRING) {
if ((meta->val.cstr = malloc(size + 1)) == NULL) {
puts("Out of memeory");
return 1;
}
sprintf(meta->val.cstr, "%s", data);
} else {
memset(meta->val.clist, 0, 128);
meta->val.clist[0] = data[0];
meta->val.clist[1] = data[1];
meta->val.clist[2] = data[2];
}

meta->type = type;

return 0;
}

void free_meta(struct meta *meta)
{
if (meta->type == STRING)
free(meta->val.cstr);
}

int main(int argc, char *argv[])
{
struct meta meta;
char list[] = {'a', '3', 'f'};

if (argc > 1) {
if(init_meta(&meta, STRING, strlen(argv[1]), argv[1]))
return 1;
} else {
init_meta(&meta, LIST, 0, list);
}

fprintf(stdout,
"meta[%d]: %s\n",
meta.type,
meta.type == LIST ? meta.val.clist : meta.val.cstr
);

free_meta(&meta);

return 0;
}

@Floris:我测试过的古怪方法之一:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stddef.h>

enum meta_type {LIST, STRING};

#define SIZE_CLIST 128

struct meta {
enum meta_type type;
union {
char clist[SIZE_CLIST];
char *cstr;
} val;
};

int init_meta(struct meta **meta, enum meta_type type, int size, char *data)
{
if (type == STRING) {
if (offsetof(struct meta, val) == 0) {
puts("Ups.");
return 2;
}
*meta = malloc(sizeof(struct meta) -
SIZE_CLIST +
sizeof(char *)
);
(*meta)->val.cstr = malloc(size + 1);
if ((*meta)->val.cstr == NULL) {
puts("Out of memeory");
return 1;
}
sprintf((*meta)->val.cstr, "%s", data);
puts((*meta)->val.cstr);
} else {
*meta = calloc(1, sizeof(struct meta));
(*meta)->val.clist[0] = data[0];
(*meta)->val.clist[1] = data[1];
(*meta)->val.clist[2] = data[2];
}

(*meta)->type = type;

return 0;
}

void free_meta(struct meta *meta)
{
if (meta->type == STRING)
free(meta->val.cstr);
free(meta);
}

int main(int argc, char *argv[])
{
struct meta *meta = NULL;
char list[] = {'a', '3', 'f'};

if (argc > 1) {
if(init_meta(&meta, STRING, strlen(argv[1]), argv[1]))
return 1;
} else {
init_meta(&meta, LIST, 0, list);
}

fprintf(stdout,
"meta[%d] %d: %s\n",
meta->type,
sizeof(*meta),
meta->type == LIST ? meta->val.clist : meta->val.cstr
);

free_meta(meta);

return 0;
}

最佳答案

union 会为最大的成员分配空间。你有一个数组和一个指针,所以它会为数组分配空间。指针的大小是固定的,指向什么并不重要。

当您使用 malloc 时,空间不是在数据结构中分配的,而是在内存中的其他地方。您将该内存位置分配给指针。

关于c - 具有 union 静态和动态字符数组的结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15294324/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com