Brainfuck口译员

Dav*_*mes -2 c interpreter brainfuck

有人请为我描述这个brainfuck解释器吗?

    #include <stdlib.h>
    char m[9999], *n[99], *r = m, *p = m + 5000, **s = n, d, c;
    main() 
    {
       for (read(0, r, 4000); c = *r; r++)
              c - ']' || (d > 1 || 
              (r = *p ? *s : (--s, r)), !d || d--), c - '[' || d++ ||
              (*++s = r), d || (*p += c == '+', *p -= c == '-', p += c == '>', 
              p -= c == '<', c - '.' || write(2, p, 1), c - ',' || read(2, p, 1));
    }
Run Code Online (Sandbox Code Playgroud)

MSN*_*MSN 13

内部循环使用短路布尔表达式(以及逗号运算符而不是分号)来计算每个brainfuck令牌.

每个实例<expr a> || <expr b>都可以翻译成if (!<expr a>) { <expr b> }

逗号运算符的每次使用(r = *p ? *s : (--s, r))都可以用分号代替.

列表p <op>= <conditional>*p+= <conditional>可以替换为if (<conditional>) p <op>= 1if (<conditional>) *p <op>= 1.并且整个括号集合可以转换为if (!d) { ... }.

一旦你完成了所有这些,你最终会得到一个非常简单的脑筋解释器.请记住,作为表达式的逗号运算符从左到右进行求值.