Описание тега brainfuck

Brainfuck (bf) - это эзотерический, полный по Тьюрингу язык программирования, известный своим минималистичным восьмисимвольным синтаксисом.

Brainfuck - это эзотерический и полный язык программирования Тьюринга, известный своим минималистичным восьмисимвольным синтаксисом.

Brainfuck использует простую модель машины, состоящую из указателя программы и инструкции, а также массива из не менее 30000 ячеек байта, инициализированных нулем. Имеется подвижный указатель данных (инициализированный для указания на крайний левый байт массива) и два потока байтов для ввода и вывода (чаще всего подключенные к клавиатуре и монитору соответственно и использующие кодировку символов ASCII).

Синтаксис языка

Существует 8 языковых команд, каждая из которых представлена ​​одним символом:

  • > - увеличить указатель данных (чтобы указать на следующую ячейку справа)
  • < - уменьшить указатель данных (чтобы указать на следующую ячейку слева)
  • + - увеличить (увеличить на единицу) байт в указателе данных
  • - - уменьшение (уменьшение на единицу) байта в указателе данных
  • . - вывести символ, значение ASCII которого является байтом в указателе данных
  • , - принять один байт ввода, сохраняя его значение в байте в указателе данных
  • [ - если байт в указателе данных равен нулю, то вместо перемещения указателя инструкции вперед к следующей команде, переместите его вперед к команде после соответствующей] команды
  • ] - если байт в указателе данных отличен от нуля, то вместо перемещения указателя инструкции вперед к следующей команде, переместите его обратно к команде после сопоставления [ команда.

Все остальные символы в исходном коде игнорируются, и поэтому для комментариев нет специального синтаксиса. Несмотря на свой минималистичный подход, этот язык является полным по Тьюрингу, что означает, что в Brainfuck можно реализовать любой алгоритм.

Семантика языка

Псевдокод языка Brainfuck

>   becomes     ++p;
<   becomes     --p;
+   becomes     ++*p;
-   becomes     --*p;
.   becomes     putchar(*p);
,   becomes     *p = getchar();
[   becomes     while (*p) {
]   becomes     }

Программа Hello world

Ниже представлена ​​программа, которая выводит Hello, world! за которым следует новая строка \n:

++++++++++[>+++++++>++++++++++>+++>+<<<<-]
>++.>+.+++++++..+++.>++.<<+++++++++++++++.
>.+++.------.--------.>+.>.

Ниже представлен тот же код с объяснением того, как он работает:

[ This program prints "Hello World!" and a newline to the screen, its
  length is 106 active command characters. [It is not the shortest.]

  This loop is a "comment loop", a simple way of adding a comment
  to a BF program such that you don't have to worry about any command
  characters. Any ".", ",", "+", "-", "<" and ">" characters are simply
  ignored, the "[" and "]" characters just have to be balanced. This
  loop and the commands it contains are ignored because the current cell
  defaults to a value of 0; the 0 value causes this loop to be skipped.
]
+++++ +++               Set Cell #0 to 8
[
    >++++               Add 4 to Cell #1; this will always set Cell #1 to 4
    [                   as the cell will be cleared by the loop
        >++             Add 2 to Cell #2
        >+++            Add 3 to Cell #3
        >+++            Add 3 to Cell #4
        >+              Add 1 to Cell #5
        <<<<-           Decrement the loop counter in Cell #1
    ]                   Loop till Cell #1 is zero; number of iterations is 4
    >+                  Add 1 to Cell #2
    >+                  Add 1 to Cell #3
    >-                  Subtract 1 from Cell #4
    >>+                 Add 1 to Cell #6
    [<]                 Move back to the first zero cell you find; this will
                        be Cell #1 which was cleared by the previous loop
    <-                  Decrement the loop Counter in Cell #0
]                       Loop till Cell #0 is zero; number of iterations is 8

The result of this is:
Cell No :   0   1   2   3   4   5   6
Contents:   0   0  72 104  88  32   8
Pointer :   ^

>>.                     Cell #2 has value 72 which is 'H'
>---.                   Subtract 3 from Cell #3 to get 101 which is 'e'
+++++++..+++.           Likewise for 'llo' from Cell #3
>>.                     Cell #5 is 32 for the space
<-.                     Subtract 1 from Cell #4 for 87 to give a 'W'
<.                      Cell #3 was set to 'o' from the end of 'Hello'
+++.------.--------.    Cell #3 for 'rl' and 'd'
>>+.                    Add 1 to Cell #5 gives us an exclamation point
>++.                    And finally a newline from Cell #6

Эта статья основана на статье из Википедии.

Подробнее