所以我想实现一个哈希查找,用于将密码子翻译成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'
];
代码无法编译,我得到了
Error: no-constant expression
我认为这有点奇怪,因为我将关联数组写为常量并将其用作查找表是微不足道的。当我附加enum例如;
enum int[string] codon_table = [...]
它似乎有效。
在定义这种关联数组时,使用enum
vs static int[string]
有什么权衡?
我做错了什么?
答案 0 :(得分:5)
试试这个:
immutable int[string] codon_table;
static this() {
codon_table = [
"ATG": 'M',
// ...
"GGA": 'G', "GGG": 'G'
];
}
我使表格不可变,因为您不太可能需要更改查找表。
也就是说,初始化程序无法正常工作,这有点奇怪。您可能希望在D论坛上发布此内容。