c – 初始化枚举索引数组?
发布时间:2020-12-16 03:15:02 所属栏目:百科 来源:网络整理
导读:gcc在C中有一个非常好的扩展,允许您使用枚举将数据保存为数组: enum keys { key_alpha = 0,key_beta = 1,key_gamma = 2 }; ValType values = { [ key_alpha ] = { 0x03b1,"alpha" },[ key_gamma ] = { 0x03b3,"gamma" },[ key_beta ] = { 0x03b2,"beta" } }
gcc在C中有一个非常好的扩展,允许您使用枚举将数据保存为数组:
enum keys { key_alpha = 0,key_beta = 1,key_gamma = 2 }; ValType values = { [ key_alpha ] = { 0x03b1,"alpha" },[ key_gamma ] = { 0x03b3,"gamma" },[ key_beta ] = { 0x03b2,"beta" } }; 这是很好的,因为如果列表必须更改,添加或删除行不会破坏分配,很明显哪个键对应于哪个值,并导致简单的代码与普通的标准数组初始化没有区别. 不幸的是,这种扩展在g中不可用. 在C中做同样事情的首选轻量级方式是什么?优选地,不是基于< map>以及使用字符串键,隐藏索引,重模板或其他CPU和内存重的东西的喜欢? 解决方法#include <iostream> #define KEYS_DEF KEY_DEF( alpha,0x03b1,"alpha" ), KEY_DEF( beta,0x03b2,"beta" ), KEY_DEF( gamma,0x03b3,"gamma" ) #define KEY_DEF( identifier,id,name ) identifier enum keys { KEYS_DEF }; #undef KEY_DEF #define KEY_DEF( identifier,name ) { id,name } struct ValType { int id; char const* name; }; ValType const values[] = { KEYS_DEF }; int main() { using namespace std; for( int i = alpha; i <= gamma; ++i ) { cout << values[i].name << endl; } } 干杯&心连心, (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |