加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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;
    }
}

干杯&心连心,

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读