在D中定义关联数组时出错

eas*_*fri 2 d

所以我想实现一个哈希查找,用于将密码子翻译成D中的氨基酸.当我写的时候

int[string] codon_table = [
  "ATG": 'M',
  "TTT": 'F', "TTC": 'F', "TTA": 'L',
  "TTG": 'L', "CTT": 'L', "CTC": 'L',
  "CTA": 'L', "CTG": 'L', "ATT": 'I',
  "ATC": 'I', "ATA": 'I', "GTT": 'V',
  "GTC": 'V', "GTA": 'V', "GTG": 'V',
  "TCT": 'S', "TCC": 'S', "TCA": 'S',
  "TCG": 'S', "CCT": 'P', "CCC": 'P',
  "CCA": 'P', "CCG": 'P', "ACT": 'T',
  "ACC": 'T', "ACG": 'T', "GCT": 'A',
  "GCC": 'A', "GCA": 'A', "GCG": 'A',
  "TAT": 'Y', "TAC": 'Y', "TAA": '*',
  "TAG": '*', "CAT": 'H', "CAC": 'H',
  "CAA": 'Q', "CAG": 'Q', "AAT": 'N',
  "AAC": 'N', "AAA": 'K', "AAG": 'K',
  "GAT": 'D', "GAC": 'D', "GAA": 'E',
  "GAG": 'E', "TGT": 'C', "TGC": 'C',
  "TGA": '*', "TGG": 'W', "CGT": 'R',
  "CGC": 'R', "CGA": 'R', "CGG": 'R',
  "AGT": 'S', "AGC": 'S', "AGA": 'R',
  "AGG": 'R', "GGT": 'G', "GGC": 'G',
  "GGA": 'G', "GGG": 'G'
  ];
Run Code Online (Sandbox Code Playgroud)

代码不编译,我得到

Error: no-constant expression
Run Code Online (Sandbox Code Playgroud)

我认为这有点奇怪,因为我将关联数组写为常量并将其用作查找表是微不足道的.当我附加enum例如;

enum int[string] codon_table = [...]
Run Code Online (Sandbox Code Playgroud)

它似乎工作.

在定义这种关联数组时使用enumvs 有什么权衡static int[string]?我究竟做错了什么?

Col*_*Two 5

试试这个:

immutable int[string] codon_table;
static this() {
    codon_table = [
        "ATG": 'M',
        // ...
        "GGA": 'G', "GGG": 'G'
    ];
}
Run Code Online (Sandbox Code Playgroud)

我使表不可变,因为你不太可能需要更改查找表.

也就是说,初始化程序不起作用有点奇怪.您可能希望在D论坛上发布此内容.