自制计算器——《自制编程语言》二 ? CharlieWang发布于 4 月 7 日 前面介绍了借助yacc和lex自制计算器。...《自制计算器(借助yacc和lex)—《自制编程语言》一》 本文介绍下不用yacc和lex的实现过程,其实就是自己编写词法解析器和词法分析器来代替yacc和lex。...基于C语言实现 文中代码为了说明大多是截图,可以对照行号介绍,不过不用担心,源代码我都传到这里了 1.自制词法分析器 说明:本计算器会将换行作为分隔符,把输入分割成一个个算式。...2.本次的计算器是以行尾单位的,st_line会保存一行中的所有信息,但在当下的编程语言中,换行一般和空白字符是等效的,因此不应该以行尾单位处理,而是从文件中逐字符(getc()等函数)读入解析会更好。...2.自制语法分析器 大多程序员即使没自制编程语言的背景,也能猜到词法分析器的运行机制,换成语法分析器就有点毫无头绪了。
用C语言做个象棋是不容易的,涉及到的知识点有很多方面,C语言里面的基本数据类型、运算符、顺序,分支,循环结构。还有运用到数组,函数,指针,以及我们的位运算等。..."仕")==0) { putimage(x,y,&t[12]); } if(strcmp(q,"帥")==0) { putimage(x,y,&t[13]); } } void qipan() { C语言学习群...:462127424 点击链接加入群聊【C语言】:C语言 //图型初始化 int gdriver, gmode; int x,y; int fillstyle; gdriver=DETECT; initgraph
《自制编程语言》学习记录,内容基本是摘抄原书其实原书并不是从头讲怎么写一个计算器的,而是上来就给了代码,对着代码讲解。计算器代码的名字为mycalc,内部完全使用double进行运算。...1.基础概念介绍 1.1 编程语言的语法处理一般有以下的过程: 1.1.1 词法分析 将源代码分割成若干个记号(token)的处理。...1.2 lex: lex 是自动生成词法分析器的工具,通过输入扩展名为.l的文件,输出词法分析器的C语言代码。 ...1.3 yacc: yacc是自动生成语法分析器的工具,输入扩展名为.y的文件,就会输出语法分析器的C语言代码。...还是没能了解太对自制编程语言知识,算是对词法分析等基础概念有点了解。后续会不借助jacc和lex重新制作一个计算器。本文结束。
继续《AI自制编程语言》系列语法解析部分,先温习编译器执行步骤如下: 编译器执行步骤 而本篇主要集中语义解析和AST树生成部分,还未实现求值(下一篇《语法解析1》实现求值功能)。
上面这种语法表达式也叫Backus-Naur 范式,其中Backus是IBM的研究员,是他发明了第一个编译器,用来编译Fortan 语言。...链接:http://tomcopeland.blogs.com/EcmaScript.html 描述的就是javascript语言的语法表达式,有兴趣的同学可以点进去看看。
在编程时,我们会初始化一个变量,给变量赋初值,例如下面语句: let x = 5*5; 上面代码被编译器解读后,变量x就会和数值25绑定在一起。...在Monkey语言中,函数跟常量一样,可以直接赋值给变量,于是它就能跟变量绑定起来,于是函数就可以像变量一样作为参数进行传递,或作为一个函数调用的返回值,首先我们先增加函数的符号对象: //change
basci编译器,C++之父Bjarne Stroustrup,C语言之父丹尼斯.里奇,java之父James Gosling。...我曾经花两年的时间在网易云课堂上完成了一个编译器的开发课程,我用java制作了一个C语言编译器,这个编译器不但能解释执行C语言,同时还能把C语言编译成java字节码,使得C语言也能运行到java虚拟机上...为了弥补这些缺陷,我打算重新用Reactjs+BootStrap的方式开发一门新编程语言的编译器,这么语言叫Monkey,它有点类似于javascript这种脚步语言,由于语法简单,实现它的编译器比实现...C语言的编译器要容易很多。...Monkey语言具备编程语言的所有要素: 1, 有类似C语言的语法结构 2, 支持变量绑定 3, 支持整形和布尔型数据类型 4, 支持算术表达式的解析 5, 一级类定义(first-class)和高阶函数
直接赋与数值不利于人的理解,于是我们可以用编程中常量定义的方法,用不同的常量来对应不同的值,例如: const LET = 0; const IDENTIFIER = 1; const EQUAL_SIGN
接着执行以下命令: npm install --save react-bootstrap 上面的命令用来安装试用与react框架的boostrap UI控件库,我们将使用它来开发我们Monkey编程语言的...接下来,我们将进入MonKey语言IDE的开发,我们将利用reactjs组件化开发的特点,通过乐高式搭积木的方式,逐步开发出一个功能丰富的页面IDE出来,我们先为项目增加一个新的react组件。...这就是我们想要的Monkey编程语言开发所用的IDE,相当于Visual Studio或Eclipse,当然现在看起来它太简陋,我们后续会慢慢增强其功能。...这里的JSX是一个比较抽象的概念,React的初学者很容易被这个概念搞得糊里糊涂,就像C语言的初学者总会被‘指针’搞得二和尚摸不在头脑一样。...我们看到,在render函数中,我们还定义了一个textAreaStyle的对象,不难看出,它实际上承担了原来CSS的作用,也就是说,在JSX中,我们可以统一用javascript语言来代替原来需要用HTML
上一节,我们利用词法解析器加上观察者模式,实现了代码语句的抽取关键字功能,对于给定代码: <text>let five = 5; let six = ...70550
前一节,我们为Monkey语言以及其编译器增加了内置API len,以及数组数据类型,内置的len函数调用能作用到数组和字符串上,分别返回数组的元素个数和字符串的字符长度。...本节我们继续增加三个能作用到数组上的内置API,这样Monkey语言能更方便的支持数组操作。 我们在这里要增加的第一个API叫first。...接下来,我们为Monkey语言增添一种最为常用的数据结构,那就是map,它能够把key和value一一对应起来,该数据结构是除了数组外,编程中最为常用的数据结构。
使用各种IDE编写代码时,其有一个功能是关键字高亮,当你敲下的字符串形成编程语言的关键字时,它的颜色会比普通变量更加靓丽显眼,而且这种高亮是即时的,当你在编辑器上敲下”if”两个字母时,这两个字母的颜色会变成引人注目的红色...关键字的即时高亮是一个难度很大技术点,由于我们自创的Monkey编程语言所使用的IDE是网页版,在web上实现关键字高亮更是颇费周折,本节技术含量很大,完成本节后,你的数据结构,算法,设计模式等技术内力会有明显提升...} .... } } 首先我们增加了一个新函数叫initKeywords,在该函数中,我们先创建一个名为keyWordMap的哈希表,这个表的key是Monkey语言关键字对应的字符串...,例如let, if , else 都是Monkey语言的关键字,哈希表的值,则是我们手动为关键字专门生成的Token对象。...在nextToken函数中,词法解析器在解析代码时,当读入一串有连续字符组成的字符串时,这个字符串可能属于Monkey语言的关键字,也可能就是普通变量而已,那么当解析到字符串时,解析器现在关键字哈希表中
一直对技术有很强的兴趣,终于,决定要写自己的语言(m语言)。那就先从最简单的开始:解释执行器。...一套完整的语言包含的肯定不止解释执行器了,还要有编译器和IDE,也就还要有语法高亮、智能提示等,不过还没学会那些,先搞个最基本的解释执行器。...语句、while语句、系统自有函数定义、用户函数定义、函数调用) 找一款词法语法解析器工具,让字符串流变成语法书(AST) 编写解释执行器 元数据收集 变量作用域定义、查找 解释执行 先设想我们的m语言语法要怎么牛
–pl/sql编程语言 –pl/sql编程语言是对sql语言的扩展,是的sql语言具有过程化编程的特性 –pl/sql编程语言比一般的过程化编程语言,更加灵活高效 –pl/sql编程语言主要用来编写存储过程和存储函数等...commit; end loop; close c2; end; 执行前 执行后 存储过程 --存储过程 --存储过程:存储过程就是提前编译好的一段pl/sql语言
语言 计算机语言指用于人与计算机之间通讯的语言,也即是平时说的编程语言 编程 指令的概念很早就形成了,其实指令本身就是一种编程 一个指令替代了一组逻辑电路或者机电式/机械式中的一个计算单元 你只需要一个指令就相当于已经操作了一整个的模块...这不也是一种编程的思维吗,只不过是指令对应硬件 随着指令在现代计算机中的应用,计算机程序得以快速的发展 因为一旦你知道计算机可以执行哪些指令,其实也就是哪些功能,具有哪些能力 你就可以把这些指令按照一定的逻辑顺序重排组装...不同的机器有不同的汇编语言 需要汇编程序翻译成计算机可以识别的二进制机器语言 本质还是面向机器的低级语言 机器语言和汇编语言都是面向硬件的具体操作的,语言对机器过分依赖,所以称之为低级语言 高级语言...为了能够更加通用的解决问题,而不是专注于硬件本身,出现了高级语言 高级语言不用关注机器的指令,使用接近人习惯的自然语言和数学语言符号 能够专注于问题本身的业务逻辑 显然高级语言也是不能直接运行于机器上的...,需要翻译程序转换为机器可以执行的目标代码程序 虽然高级语言不涉及寄存器这些东西,不需要你了解硬件 但是这是高级语言隐藏了她们,而不是说这些东西不存在不重要,所有的语言都逃不过这一关 始终是要编程机器语言的
我们的编译器所至此的Monkey语言其实与Javascript没有太大区别,它支持多种数据类型,例如整形,布尔值,数字,字符串,它还支持复杂数据结构,例如数组和哈希表,它具有高级语言特点,例如支持函数传参...,函数闭包调用等,唯一遗憾的是它暂不支持面向对象编程的类定义,但只要你吃透了课程所介绍的编译原理,添加相应功能并没有太大难度,事实上当前Monkey语言编译器已经是一个完整可用的编程语言了,据说当今世界能做编译器的人最多坐满一个
编程语言之间的相似之处比人们乍看上去的还要多得多。这意味着如果你很了解某一门编程语言,学习其他编程语言(至少同类型的编程语言)就变得十分容易。...这也就是为什么好的软件公司在招人的时候并不十分介意你是否已经掌握了他们所需的编程语言技能,他们会转而去看你了解多少门编程语言,期望在你的简历上看到你已经掌握了许多足够多样化的编程语言,此时学习一门新语言对于你来说并非难事...了解一门编程语言意味着你了解如何在程序中自如地使用这些控制结构和控制流来表达思想。 不同编程语言之间的语法可能会有些许不同,但是编程语言之间基本的表达式大体是一样的。...一门没人愿意使用的编程语言能好到哪去? 在编程语言的表达能力和简洁程度上做出权衡是一门艺术。...谈到自然语言与编程语言之间的差异,编程语言比自然语言更加严格,对错误的容许程度更低。这是因为人类语言具有显著的内置冗余机制,容许我们使用上下文来消除歧义。
语言是交流的基础,那么,C语言也是交流的基础。 那么,与谁交流呢? 人与人是用汉语,英语等交流的,那么人与计算机就是用编程语言交流的。...故,C语言是一门人与计算机交流的语言,当然,语言不只有一种,还有Java,python等。 语言是在发展过程中不断完善的,C语言同样如此。...C语言最初是由B语言发展而来,而B语言最初为Unix系统服务。...Unix系统和B语言由贝尔实验室的肯·汤普森和丹尼斯·里奇发明,之后丹尼斯·里奇和布莱恩·柯林汉在B语言的基础上进行了改动,更名为C语言。...而语言需要统一性,所以美国国家标准协会(ANSI)对C语言进行标准化。 故有C89,C90,C11等标准出现。 语言,编译环境缺一不可,什么是编译环境,即编译工具。
想了解编程语言我们先要知道什么叫做“编程”,编程的意思就是编写流程,那么只要能编写流程的语言都应该叫做编程语言。...据不完全统计,所有编程语言加起来超过600种,其中用的比较多的也就前20种语言,Python不仅是其中一种而且这两年已经稳居第一名的宝座了。...9.jpg 一、低级语言和高级语言 计算机编程语言能够实现人与机器之间的交流和沟通,而计算机编程语言主要包括汇编语言、机器语言以及高级语言,具体内容如下: 汇编语言 该语言主要是以缩写英文作为标符进行编写的...高级语言 所谓的高级语言,其实是由多种编程语言结合之后的总称,其可以对多条指令进行整合,将其变为单条指令完成输送,其在操作细节指令以及中间过程等方面都得到了适当的简化,所以,整个程序更为简便,具有较强的操作性...二、交互原理 编程语言承接的就是人与机器之间的交互中介,程序员通过编程语言编写一段执行命令的流程代码,这段代码在执行前会被编译成底层语言,比如python就会直接编译成C语言,C语言计算机也是看不懂的,
前几节,我们介绍了如何使用语法解析算法对代码进行解析。语法解析的目的是为了明白代码语句的意图,例如对于语句: c = a + b; 语法解析后,编译器就明白代码...
领取专属 10元无门槛券
手把手带您无忧上云