我能做这样的事情吗?我想在我的枚举type_t中使用数据类型而不是常量。
typedef struct {
    char id;
    long data;
} type1_t;
typedef struct {
    char id;
    long data;
    float moredata;
} type2_t;
typedef enum {
    type1_t, type2_t
} type_t;
typedef struct {
    type_t type;
    char* something;
} midas;
midas obj1;
obj1.type = type1_t;
obj1.type.id = 0;
obj1.type.data = 123;
midas obj2;
obj2.type = type2_t;
obj2.type.id = 3;
obj2.type.data = 456;
obj2.type.moredata = 3.14;在本例中,midas结构的type变量应该引用type1_t或type2_t。因此,如果我将类型设置为type2_t,那么它的大小应该比设置type1_t时要大。
发布于 2010-11-11 04:51:15
不,你不能这么做。如果您使用的是C++,您可以使用模板来实现这一点。但是在C中没有“类型枚举”机制。
你可以考虑成立一个工会:
typedef enum {
    type1, type2
} type_t;
typedef struct {
    type_t typecode;
    union {
        type1_t type1value;
        type2_t type2value;
    };
    char* something;
} midas;这将导致midas.type1value和midas.type2value占用相同的内存空间。联合占用的内存量将等于存储它所包含的最大数据类型所需的内存量。
然后,您必须查看midas.typecode并考虑使用哪个工会成员。如果你使用了错误的方法,你会得到无效的数据,这可能会导致程序崩溃,所以要小心。
https://stackoverflow.com/questions/4148916
复制相似问题