Compiler Principle
1.Einleitung
1.1 Der Überblick über Compiler
1.1.1 Lexikalische Analyse
Die lexikalische Analyse zerteilt den eingelesenen Quelltext in lexikalische Einheiten (Tokens) verschiedener Typen, zum Beispiel Schlüsselwörter, Bezeichner, Zahlen, Zeichenketten oder Operatoren. Dieser Teil des Compilers heißt Scanner oder Lexer.
1.1.2 Syntaktische Analyse
Die syntaktische Analyse überprüft, ob der eingelesene Quellcode in einer korrekten Struktur der zu übersetzenden Quellsprache vorliegt, das heißt der kontextfreien Syntax (Grammatik) der Quellsprache entspricht
1.1.3 Semantische Analyse
Die semantische Analyse überprüft die statische Semantik, also über die syntaktische Analyse hinausgehende Bedingungen an das Programm.
Verschiedene Phase der Compiler:

Eine Übersetzung des Satzes:

1.1.4 Interpreter
Ein Interpreter ist ein Computerprogramm, das einen Programm-Quellcode im Gegensatz zu Assemblern oder Compilern nicht in eine auf dem System direkt ausführbare Datei übersetzt, sondern den Quellcode einliest, analysiert und ausführt.
1.1.5 Compiler
Ein Compiler ist ein Computerprogramm, das Quellcodes einer bestimmten Programmiersprache in eine Form übersetzt, die von einem Computer (direkter) ausgeführt werden kann.
2.Lexikalische Analyse
2.1 Kette und Sprache
Kette:Die Kette in Alphabet ist endliche Sequenz der Alphabetstabelle
Sprache:Eine Ketteliste der Alphabet

2.2 Regulärer Ausdruck
Regulärer Ausdruck:Ein regulärer Ausdruck ist in der theoretischen Informatik eine Zeichenkette, die der Beschreibung von Mengen von Zeichenketten mit Hilfe bestimmter syntaktischer Regeln dient.
Regulärer Liste:ist eine Sprache,die mit regulärer Ausdruck ausdrucken kann.
Priorität der Rechnung:Closure>Verbindung>Auswahl

2.3 Die Definition der Regulärer Ausdruck
Man kann regulärer Ausdruck bennen und mit diese Name entsprechende regulärer Ausdruck zitieren.
Die Difinition der Regulärer Ausdruck:
Form wie
d1->r1
d2->r2
···
dn->rn
Zum Beispieil:
letter_->[A-Za-z_]
digit->0|1|···|9
id->letter_(letter_|digit)*
number->digit+(.digit+)?(E(+/-)?digit+)?
2.4 Nichtdeterministischer endlicher Automat
Ein nichtdeterministischer endlicher Automat (NEA; englisch nondeterministic finite automaton, NFA) ist ein endlicher Automat, bei dem es für den Zustandsübergang mehrere gleichwertige Möglichkeiten gibt. Im Unterschied zum deterministischen endlichen Automaten sind die Möglichkeiten nicht eindeutig, dem Automaten ist also nicht vorgegeben, welchen Übergang er zu wählen hat.

2.5 Deterministischer endlicher Automat
Ein deterministischer endlicher Automat (DEA; englisch deterministic finite automaton, DFA) ist ein endlicher Automat, der unter Eingabe eines Zeichens seines Eingabealphabetes (den möglichen Eingaben) von einem Zustand, in dem er sich befindet, in einen eindeutig bestimmten Folgezustand wechselt. Er unterscheidet sich darin von nichtdeterministischen endlichen Automaten, deren Zustandswechsel sich nicht immer deterministisch ereignen müssen.
2.5.1 Die Umsetzung von NFA nach DFA

Beispiel 1:Bildst du fur (a|b)*a(a|b) DFA
Zuerst zeichnen wir NFA

Bilden wir einen Dtran,gesamt vier verschiedene Liste

Abgrund des Dtrans zeichnen wir die Abbildung der DFA
Beispiel2:DFA,Die Binarzahl,die in {0,1} mit 5 Division ohne Rest machen kann,kann erkannt werden.

3.Syntaktische Analyse
3.1 Die Definition der Kontextfreie Grammatik
Normalerweise gesagt,G ist ein vierTuple(VT,VN,S,P),darunter:
(1)VT ist eine nicht leer und endliche Menge,deren Element wird als Terminalsymbol bezeichnet
(2)VN ist eine nicht leer und endliche Menge,deren Element wird als Nichtterminalsymbol bezeichnet
(3)S ist eine NichtTerminalsymbol,bezeichnen wir Startsymbol
(4)P ist eine Menge von Produktion
3.2 Folgendes Zeichen wird als Terminalsymbol/Nichtterminalsymbol benutzt

3.3 Die Zwei Bedeutung der Grammatik
Aufgrund der Grammatiks E->E+E|E*E|(E)|-E|id

3.4 Beseitigen Linke Rekursion
Es besteht A=>Aα,bezeichnen wir diese Grammatik Linke Rekursion
Linke Rekursion A->Aα|β kann mit nicht Linke Rekursion
A->βA'
A'->αA'|ε
ersetzen

3.5 LL(1) Grammatik
3.5.1 Die Definition der LL(1)

3.5.2 Berechnen First Menge
Methode:Berechnen wir Grammatik Symbolzeichenfolge,die Produktion der Terminalsymbol enthält,dann erhalten wir linken Seite der Produktion
Beispiel:FIRST(E) = FIRST(T) = FIRST(F) = {(,id} (Die Produktion müssen Terminalsymbol haben)
FIRST(E') = {+,ε} (Die Grammatik hier enthält Terminalsymbol,unnötig nach unten zu berechnen)
FIRST(T') = {*,ε} (gleich wie oben)

3.5.3 Berechnen Follow Menge
Methode:
berechnen wir der Rechte Seite des X,den Follow(X) Menge umfassen;
Vorhergehend Grammatik Symbolzeichenfolgen sitzen in dem Produktion der Follow;
Falls die Rechte Seite der X kein Terminalsymbol hat,fügen First Menge der Rechten Seite der X hinein;
Beispiel:FOLLOW(E) = FOLLOW(E') = {),$} (haben kein Verhältnis zu E',schauen wir der rechten Seite der Produktion der E,Ergebnis ist ')',legen es und '$' in Follow Menge)
FOLLOW(T) = FOLLOW(T') = {+,),$} (Weil First(E') ε und + umfasst,ε wird defalut beseitigt, legen '+' in Follow(E))
FOLLOW(F) = {+,*,),$} (Die rechte Seite der F hat kein Terminalsymbol F,fügen First(T') Follow(T) hinein)

Compiler Principle的更多相关文章
- APS审核经验+审核资料汇总——计算机科学与技术专业上海德语审核
1.APS是什么 德国驻华使馆文化处留德人员审核部(简称APS)成立于2001年7月,是由德国驻华使馆文化处和德意志学术交流中心(DAAD)在北京共同合作成立的服务机构. APS是中国学生前往德国留学 ...
- The IDL compiler
The IDL compiler or bindings generator transcompiles Web IDL to C++ code, specifically bindings betw ...
- Java compiler level does not match解决方法
从别的地方导入一个项目的时候,经常会遇到eclipse/Myeclipse报Description Resource Path Location Type Java compiler level d ...
- idea报错:error java compilation failed internal java compiler error
idea下面报如下问题 error java compilation failed internal java compiler error 解决办法:Setting->Compiler-> ...
- 使用Google Closure Compiler高级压缩Javascript代码注意的几个地方
介绍 GCC(Google Closure Compiler)是由谷歌发布的Js代码压缩编译工具.它可以做到分析Js的代码,移除不需要的代码(dead code),并且去重写它,最后再进行压缩. 三种 ...
- SSE指令集学习:Compiler Intrinsic
大多数的函数是在库中,Intrinsic Function却内嵌在编译器中(built in to the compiler). 1. Intrinsic Function Intrinsic Fun ...
- c++ builder 2010 错误 F1004 Internal compiler error at 0x9740d99 with base 0x9
今天遇到一个奇怪的问题,拷贝项目后,在修改,会出现F1004 Internal compiler error at 0x9740d99 with base 0x9 ,不管怎么改,删除改动,都没用,关闭 ...
- Android requires compiler compliance level 5.0 or 6.0. Found '1.4' instead的解决办法
今天在导入工程进Eclipse的时候竟然出错了,控制台输出的是: [2013-02-04 22:17:13 - takepicture] Android requires compiler compl ...
- Compiler Error Message: CS0016: Could not write to output file 回绝访问
Compiler Error Message: CS0016: Could not write to output file 'c:\Windows...dll' 拒绝访问 C:\Windows\Te ...
随机推荐
- Unity&C# SingerMonoManager泛型单例
管理各种管理器 ///为什么需要单例 ///单例模式核心在于对于某个单例类,在系统中同时只存在唯一一个实例,并且该实例容易被外界所访问: ///避免创建过多的对象,意味着在内存中,只存在一个实例,减少 ...
- 【转】.NET内存管理、垃圾回收
1. Stack和Heap 每个线程对应一个stack,线程创建的时候CLR为其创建这个stack,stack主要作用是记录函数的执行情况.值类型变量(函数的参数.局部变量 等非成员变量)都分配 ...
- WindowsPhone模拟简易Toast弹出框
Coding4Fun这个开源控件中有ToastPrompt这个弹出框组件,但是由于Coding4Fun太庞大,如果只用到ToastPrompt这个控件的话,整个引用不太值当的.于是自己写了一个差不多的 ...
- kolla 安装
下载 kolla-ansible 和 kolla 源码: git clone http://git.trystack.cn/openstack/kolla-ansible -b stable/quee ...
- “全栈2019”113篇Java基础学习资料及总结
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- 配置DNS服务器转发器
1.(windows server 2008 r2)控制面板->管理工具->服务器管理器->DNS->服务器图标->属性 2.转发器->编辑 3.填写DNS并点击确 ...
- Python数据采集处理分析挖掘可视化应用实例
距离上一次发Python的技术贴已经过去两年了,这两年大法初成,并在知乎谢了相关技术专栏.现在搬运如下,均为原创,转载需注明出处哦! https://zhuanlan.zhihu.com/p/2957 ...
- 《快学Scala》第六章 对象 第七章 包和引入
- CVE-2018-15982漏洞复现
作者:欧根 漏洞信息:CVE-2018-15982 Adobe已发布适用于Windows,macOS,Linux和Chrome OS的Adobe Flash Player安全更新.这些更新解决一个 ...
- Jquery选择器 选择一个不存在的元素 为什么不会返回 false
不管找没找到,$()函数都会返回一个jquery对象,这个jquery对象有个length属性,表示找到多少个匹配的DOM元素,为0就是没找到.