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; } }
干杯&心连心,
原文地址:https://www.jb51.cc/c/112128.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。