【问题标题】:Struct array indexing in CC中的结构数组索引
【发布时间】:2017-12-15 20:33:25
【问题描述】:

我想以这样的方式定义结构数组,以便可以轻松执行搜索操作,并且可以使用枚举值检索字符串。

例如:

enum MY_ENUM { 
    MY_ENUM_VAL = 0,
    MY_ENUM_VAL_8 = 8,
    MY_ENUM_VAL_50 = 50,
    MY_ENUM_VAL_200 = 200,
    MY_ENUM_VAL_565 = 565,
};

struct my_struct {
    int val;
    char *str;
};


/* Struct array */
struct my_struct my_struct_array[] = {
    { MY_ENUM_VAL,  "str0" },
    { MY_ENUM_VAL_8, "str8" },
    { MY_ENUM_VAL_50, "str50" },
    { MY_ENUM_VAL200, "str200" },
    { MY_ENUM_VAL_565, "str565" },
};

像这样定义数组的优点是我可以进行搜索操作,而且如果我在数组中找不到任何值,那么我可以分配一些默认值。但是如果我想使用枚举值来查找一些字符串,比如

char *str50 = my_struct_array[MY_ENUM_VAL50].str; // this won't work.

如果我根据下面的枚举值进行索引,那么我无法进行搜索操作。另外,如果我有一些像 300 这样的随机值,我可能会得到一些垃圾值。

/* String array */
const char *my_string_array[] = {
    [MY_ENUM_VAL] = "str0",
    [MY_ENUM_VAL_8] = "str8",
    [MY_ENUM_VAL_50] = "str50",
    [MY_ENUM_VAL200] = "str200",
    [MY_ENUM_VAL_565] = "str565",
};

定义数组以实现上述两种操作的最佳/最佳方式是什么?

【问题讨论】:

  • " 但是,如果我想使用枚举值来查找一些字符串,比如..." - 简单明了,你做不到。这不是您的基本数组的定义方式。当然,您可以建立一个由 566 个指针组成的数组,除了少数几个都初始化为您的“默认值”,其余的都设置为您的特定字符串。以复杂(和明显)的存储设施和初始化设置为代价,您不会获得比直接查找更好的性能。也就是说,如果这在某种程度上是您代码的关键性能路径,哇。

标签: c arrays enums


【解决方案1】:

快速搜索不是一项简单的操作。 C 语言没有提供简单的方法来处理(键、值)映射,例如 C++ 中的 std::mapstd::unordered_mapdict 在 Python 中。您只能使用标准库中的函数。 C99 定义了bsearch,它允许在排序数组中进行二分搜索,Posix 定义了lsearch(线性搜索)和hsearch(使用密钥哈希直接访问)。或者在普通的单个 C 中,扫描数组以查找您的密钥。

【讨论】:

  • “C 语言没有提供处理 ..map 的简单方法”——不是标准库,不,但总是可以为它编写函数。在多大的数组大小下,这将优于简单循环? (我同意,这将是我最初的解决方案,直到我需要它来处理 huge 列表。)
猜你喜欢
  • 1970-01-01
  • 2016-11-25
  • 1970-01-01
  • 1970-01-01
  • 2018-09-22
  • 1970-01-01
  • 2013-04-30
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多