C 中字串到枚舉的高效轉換
在C 中使用枚舉時,您可能會遇到需要將字符串轉換為其對應的枚舉枚舉值。雖然 switch 語句就足夠了,但對於大量枚舉值來說它可能會變得很麻煩。本文探討了高效字串到枚舉轉換的替代方法。
std::map 解決方案
一種方法是建立 std::map
C 11 語法糖
對於 C 11 及更高版本,可以使用更簡潔的解決方案。使用靜態初始化的 std::unordered_map,您可以使用花括號優雅地填充映射:
static std::unordered_map<std::string,E> const table = { {"a",E::a}, {"b",E::b} };
要執行查找,只需在表上使用 find() 方法並檢查迭代器是否有效。如果找到,您可以直接檢索對應的枚舉值。
範例
例如,考慮以下枚舉聲明:
enum class E { a, b, c };
且字串「a」,可以使用表格將其轉換為對應的枚舉值:
auto it = table.find("a"); if (it != table.end()) { E result = it->second; // ... }
此方法為C 中的字串轉換為枚舉提供了簡潔高效的解決方案,降低了長switch 的複雜度宣告。
以上是如何在 C 中高效地將字串轉換為枚舉?的詳細內容。更多資訊請關注PHP中文網其他相關文章!