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&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...