编程语言BrainkFuck
BrainFuck由Urban Müller在1993年创建,是经常被吐槽的语言,不过我觉得除了名字其它都还挺正常的,没错我觉得这个语言设计的很正常没有Fuck到我的脑子,大概是因为我根本就没有脑子吧…
语言简介:
使用指针寻址来操作内存,运行时需要0~32767个字节的内存空间,可循环寻址,数据单位是8bit,数据范围是0~255,可循环溢出。
8种操作符:
> 将寻址指针向右移动一位
< 将寻址指针向左移动一位
+ 将寻址指针指向的内存空间值加1
- 将寻址指针指向的内存空间值减1
[ 如果寻址指针指向的内存空间的值为0,则跳转到下一个]后面第一个字符开始执行
] 如果寻址指针指向的内存空间的值不为0,则跳转到上一个[后面第一个字符开始执行
条件判断和循环就是通过[和]来实现的,使用当前寻址指针指向的空间存储要循环的次数,当循环次数为1的时候就相当于if条件判断为true。
想一下为什么+-><这种不干脆支持+2+3+5这种操作呢?好多个++++很麻烦的啊,其实+就相当于+1,改成别的值在语言上并不会有歧义,但是这个BrainFuck语言就是面向单字节操作的,数据单位是单字节,解释器解释代码的时候也是单字节解释的,如果支持在后面指定要加的数值的话,对于个位数还好,如果是+100这种的话解释器解释的时候就需要能够识别出100这三个连续的字符是用来组成一个数字的,不再是每个字符都可以独立解析,增加了解释器的难度,所以我觉得这个语言纯粹就是用来让人写解释器练手的。
解释器思路:
内存空间可以动态分配,初始大小为0,当用到的时候检查寻址指针大小与当前已经分配的内存空间大小不够再扩展内存空间。
这么变态的语言总是需要注释的吧,暂定单字符注释支持%和#两种。
一个简单的解释器如下:
#! /usr/bin/python3
# -*- coding: utf-8 -*-
"""
BrainFuck解释器
""" DATA_MIN = 0
DATA_MAX = 255 MEMORY_ADDRESS_MIN = 0
MEMORY_ADDRESS_MAX = 32767 def bf_exec(code):
code_point = 0
memory = []
memory_point = 0
while code_point < len(code):
c = code[code_point]
code_point += 1
if c == '+':
memory_extend(memory, memory_point)
memory[memory_point] = memory[memory_point] + 1 if memory[memory_point] < DATA_MAX else DATA_MIN
elif c == '-':
memory[memory_point] = memory[memory_point] - 1 if memory[memory_point] > DATA_MIN else DATA_MAX
elif c == '>':
memory_point = memory_point + 1 if memory_point < MEMORY_ADDRESS_MAX else MEMORY_ADDRESS_MIN
elif c == '<':
memory_point = memory_point - 1 if memory_point > MEMORY_ADDRESS_MIN else MEMORY_ADDRESS_MAX
elif c == '[':
if memory[memory_point] == 0:
while code[code_point] != ']':
code_point += 1
elif c == ']':
if memory[memory_point] != 0:
while code[code_point] != '[':
code_point -= 1
elif c == '.':
print('%c' % memory[memory_point], end='')
elif c == '%' or c == '#':
while code[code_point] != '\n':
code_point += 1 def memory_extend(memory, memory_point):
while memory_point <= MEMORY_ADDRESS_MAX and len(memory) - memory_point < 1:
memory.append(0) if __name__ == '__main__':
c1 = """
++++++++[>+++++++++ % hello-world.
<-]>.<+++++[>++++++<-]>-.+++++++..
+++.<++++++++[>>++++<<-]>>.<<++++[>
------<-]>.<++++[>++++++<-]>.+++.
------.--------.>+.
"""
bf_exec(c1)
运行效果:

相关资料:
1. BrainFuck解释过程在线演示: https://fatiherikli.github.io/brainfuck-visualizer/
2. http://esolangs.org/wiki/ook!
3. http://esolangs.org/wiki/Language_list
.
编程语言BrainkFuck的更多相关文章
- 我想立刻辞职,然后闭关学习编程语言,我给自己3个月时间学习C语言!这样行的通吗
文章背景,回答提问:我想立刻辞职,然后闭关学习编程语言,我给自己3个月时间学习C语言!这样行的通吗? 我的建议是这样:1. 不要辞职.首先说,你对整个开发没有一个简单的了解,或一个系统的入门学习.换句 ...
- Bash 脚本编程语言中的美学与哲学
我承认,我再一次地当了标题党.但是不可否认,这一定是一篇精华随笔.在这一篇中,我将探讨 Bash 脚本语言中的美学与哲学. 这不是一篇 Bash 脚本编程的教程,但是却能让人更加深入地了解 Bash ...
- [C#版本]有趣啊!各种编程语言实现 2 + 2 = 5
首页新闻里面那个 [新闻头条]有趣啊!各种编程语言实现 2 + 2 = 5 其他的就不评论的,但是其中C#版的 真是逗比啊...评论中各种吐槽有木有... static void Main (stri ...
- Atitit 编程语言编程方法的进化演进 sp COP ,AOP ,SOP
Atitit 编程语言编程方法的进化演进 sp COP ,AOP ,SOP 1.1. Sp oop>>COP ,AOP ,SOP1 1.2. Sp oop 结构化方法SP(Stru ...
- Atitit. 提升存储过程与编程语言的可读性解决方案v3 qc25.docx
Atitit. 提升存储过程与编程语言的可读性解决方案v3 qc25.docx 1. 大原则:分解+命名1 1.1. 命名规范1 1.2. 分层.DI和AOP是继OO1 1.3. 运算符可读性一般要比 ...
- 【转】最流行的编程语言JavaScript能做什么?
本文转自互联网! 首先很遗憾的一点是,“PHP虽然是最好的语言”,但是它不是最流行的语言. 对不起的还有刚刚在4月TIOBE编程语言排行榜上榜的各个语言: 你们都很棒,但是你们都担当不了这个大任. 开 ...
- 2017年"程序媛和工程狮"绝对不能忽视的编程语言、框架和工具
2017年"程序媛和工程狮"绝对不能忽视的编程语言.框架和工具 在过去的一年里,软件开发行业继续大踏步地向前迈进.回顾 2016 年,我们看到了更多新兴的流行语言.框架和工具, ...
- 中文编程语言Z语言开源正式开源!!!
(Z语言基于.NET环境,源码中有很多高技术的代码,让更多的人知道对大家有会有很好的帮助,请管理员一点要批准放在首页) 本人实现的中文编程语言Z语言现在正式开源,采用LGPL协议. 编译器核心的网址为 ...
- TKT中文编程语言简介
TKT中文编程语言简介 TKT语言是新型的类似自然语言的汉语编程语言. 它是基于新的语言设计思想创造的语言,和现存的易语言.习语言.O语言.汉编等中文编程语言没有关系. TKT语言特点一: 中文编程 ...
随机推荐
- 项目上线,php的错误信息必须不让其在页面中显示给客户,
对于PHP开发者来 说,一旦某个产品投入使用,应该立即将 display_errors选项关闭,以免因为这些错误所透露的路径.数据库连接.数据表等信息而遭到黑客攻击.但是,任何一个产品在投入使用后,都 ...
- Java Queue 专题
关于java中的Queue,经常用到,做个总结 Queue是一种很常见的数据结构类型,在java里面Queue是一个接口,它只是定义了一个基本的Queue应该有哪些功能规约. (Java中的集合包括三 ...
- Redis在Windows环境下单机安装及远程访问方案
一.下载Windows版Redis 打开https://github.com/MicrosoftArchive/redis/tags地址,找到最新版Redis安装包(Redis-x64-3.2.100 ...
- 【Linux】Linux定时任务Crontab命令详解
linux 系统则是由 cron (crond) 这个系统服务来控制的.Linux 系统上面原本就有非常多的计划性工作,因此这个系统服务是默认启动的.另 外, 由于使用者自己也可以设置计划任务,所以, ...
- 在HL引擎中制作自定义高清贴花
你是不是想过要做自定义的子弹孔.喷漆或者一些自定义的痕迹呢? 如果按照HL引擎的基本FA,首先要在decals.wad里加入我们自定义的纹理,然后利用gEngfuncs.pEfxAPI->R_D ...
- Shell脚本创建Nginx的upstream及location配置文件
#!/bin/sh ##################################################### # Name: create_nginx_conf.sh # Versi ...
- LaTex Font Size 字体大小
目录 命令 效果图 命令 LaTex中字体大小由以下命令控制: \tiny \scriptsize \footnotesize \small \normalsize \large \Large \LA ...
- 【Learning】辛普森积分
辛普森积分 这种积分法很暴力:只要求你实现出函数求值\(f(x)\). 使用辛普森积分,我们可以求出函数一段区间\([l,r]\)的近似积分.记\(mid=\frac{l+r}2\),有: \[ \i ...
- NetApp存储方案及巡检命令
一.MCC概述 Clustered Metro Cluster(简称MCC)是Netapp Data Ontap提供的存储双活解决方案,当初的方案是把1个FAS/ V系列双控在数据中心之间拉远形成异地 ...
- Android获取长按按键响应
Android获取长按按键响应http://www.2cto.com/kf/201312/261719.html Android下Listview的onItemClick以及onItemLongCli ...