c – 初始化枚举索引数组?

前端之家收集整理的这篇文章主要介绍了c – 初始化枚举索引数组?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
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;
    }
}

干杯&心连心,

猜你在找的C&C++相关文章