所以我想实现一个哈希查找,用于将密码子翻译成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]?我究竟做错了什么?
试试这个:
immutable int[string] codon_table;
static this() {
codon_table = [
"ATG": 'M',
// ...
"GGA": 'G', "GGG": 'G'
];
}
Run Code Online (Sandbox Code Playgroud)
我使表不可变,因为你不太可能需要更改查找表.
也就是说,初始化程序不起作用有点奇怪.您可能希望在D论坛上发布此内容.