c array wrapper struct 不允许 malloc

标签 c struct stack wrapper

(顺便说一下,我不允许在这里面 malloc,我在为 c99 用 c 写) 我正在尝试在 c 中为数组创建一个包装器结构以保持整洁,所以我不需要继续传递数组指针和长度,并且可以只使用一个结构:

#define MAX_LEN 64

typedef struct {
    uint8_t data[MAX_LEN];
    size_t   len;
} byteArray_t;

如果 MAX_LEN 是已知的,那很好,但是有没有办法使长度变量在编译时已知,所以例如我可以有类似的东西:

typedef struct {
    byteArray_t tag;
    byteArray_t length;
    byteArray_t value;
} tlv_t;

其中对应于 tag 的数组的大小为 MAX_TAG_LEN 等等 - 所以我需要以某种方式告诉编译器情况就是这样...

有人有什么想法吗?谢谢!

编辑

好的,很抱歉造成您的困惑。这就是我想要做的。 我目前基本有以下结构:

// tag object
typedef struct {
    uint8_t  data[MAX_TAG_LENGTH_IN_BYTES];
    uint32_t len;
} tlvTag_t;

// length object
typedef struct {
    uint8_t  data[MAX_LENGTH_OF_LENGTH_IN_BYTES];
    uint32_t len;
} tlvLength_t;

typedef struct tlv tlv_t;

// value object definition
typedef struct {
    // can consist of a byte array, or a list of sub TLVs
    union {
        uint8_t data[MAX_VALUE_LENGTH_IN_BYTES];
        // data can be parsed into subTLVs
        tlv_t* subTLVs;
    };

    // need to store the number of subTLVs
    uint32_t numberOfSubTLVs;

    // len is the total length of the data represented:
    // the total length of the subTLVs placed end to end
    // or the length of the data array.
    uint32_t len;

} tlvValue_t;

// tlv object definition
struct tlv {
    tlvTag_t    tag;
    tlvLength_t len;
    tlvValue_t  value;

    // total length of entire tlv block (not value length)
    // (if there are sub TLVs, place them end to end)
    uint32_t totalLen;
};

我认为如果我可以将数组包装在另一个结构中以避免所有代码重复并能够传递更少的参数,那么设计会更好,但我不能,因为我不知道如何告诉编译器创建不同大小的字节数组——也许可以使用宏?希望这是有道理的。

最佳答案

您似乎正试图以某种方式声明一个其内容取决于参数的结构。在 C++ 中,这可以通过模板实现:

template <size_t MAX_LEN>
struct byteArray_t
{
    uint8_t data[MAX_LEN];
    size_t   len;
};

...
byteArray_t<MAX_TAG_LENGTH_IN_BYTES> tag;
byteArray_t<MAX_LENGTH_OF_LENGTH_IN_BYTES> len;
...

这是尽可能简单的。

要在 C 中完成相同的操作,您可以使用宏:

#define DECLARE_BYTE_ARRAY_T(your_type_name, MAX_LEN) \
typedef struct { \
    uint8_t data[MAX_LEN]; \
    size_t   len; \
} your_type_name

DECLARE_BYTE_ARRAY_T(tlvTag_t, MAX_TAG_LENGTH_IN_BYTES);
DECLARE_BYTE_ARRAY_T(tlvLenght_t, MAX_LENGTH_OF_LENGTH_IN_BYTES);

...
tlvTag_t tag;
tlvLength_t len;

或者(相同)不声明类型(如果您的结构不需要名称则很好):

#define BYTE_ARRAY_T(MAX_LEN) \
struct { \
    uint8_t data[MAX_LEN]; \
    size_t   len; \
}

BYTE_ARRAY_T(MAX_TAG_LENGTH_IN_BYTES) tag;
BYTE_ARRAY_T(MAX_LENGTH_OF_LENGTH_IN_BYTES) len;

这可能比您已有的代码稍微好一些。然而,在我看来,这不值得付出努力,因为任何重要的宏都会降低代码的可读性。

关于c array wrapper struct 不允许 malloc,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16794111/

相关文章:

C、SDL : error: cannot convert 'SDL_Surface*' to 'SDL_Surface* (*)[15]

c - 使用 memcmp 时出现段错误

c - Enter E-100E 以太网卡所需的 RTL-8139 驱动程序 - 无法编译源文件

c++ - 为什么结构体的 sizeof 不等于每个成员的 sizeof 之和?

java - Java代码中的奇怪输出(方形符号)

c++ - 通过复制返回局部变量 - 它是如何工作的

python - 在 python 中使用 ctypes 从 "foreign functions"返回 NULL 指针时会发生什么?

c - 用c将结构写入文件

c - 通过套接字发送结构

C++ 函数调用与堆栈上推送/弹出的新 block