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 automatonNFA) 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 automatonDFA) 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的更多相关文章

  1. APS审核经验+审核资料汇总——计算机科学与技术专业上海德语审核

    1.APS是什么 德国驻华使馆文化处留德人员审核部(简称APS)成立于2001年7月,是由德国驻华使馆文化处和德意志学术交流中心(DAAD)在北京共同合作成立的服务机构. APS是中国学生前往德国留学 ...

  2. The IDL compiler

    The IDL compiler or bindings generator transcompiles Web IDL to C++ code, specifically bindings betw ...

  3. Java compiler level does not match解决方法

    从别的地方导入一个项目的时候,经常会遇到eclipse/Myeclipse报Description  Resource Path Location Type Java compiler level d ...

  4. idea报错:error java compilation failed internal java compiler error

    idea下面报如下问题 error java compilation failed internal java compiler error 解决办法:Setting->Compiler-> ...

  5. 使用Google Closure Compiler高级压缩Javascript代码注意的几个地方

    介绍 GCC(Google Closure Compiler)是由谷歌发布的Js代码压缩编译工具.它可以做到分析Js的代码,移除不需要的代码(dead code),并且去重写它,最后再进行压缩. 三种 ...

  6. SSE指令集学习:Compiler Intrinsic

    大多数的函数是在库中,Intrinsic Function却内嵌在编译器中(built in to the compiler). 1. Intrinsic Function Intrinsic Fun ...

  7. c++ builder 2010 错误 F1004 Internal compiler error at 0x9740d99 with base 0x9

    今天遇到一个奇怪的问题,拷贝项目后,在修改,会出现F1004 Internal compiler error at 0x9740d99 with base 0x9 ,不管怎么改,删除改动,都没用,关闭 ...

  8. 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 ...

  9. 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 ...

随机推荐

  1. Net系列框架-Dapper+AutoFac 基于接口

    Net系列框架-Dapper+AutoFac 基于接口 工作将近6年多了,工作中也陆陆续续学习和搭建了不少的框架,后续将按由浅入深的方式,整理出一些框架源码,所有框架源码本人都亲自调试通过,如果有问题 ...

  2. c语言第一次作业--顺序、分支结构

    1.1思维导图 1.2.1本周学习体会以及代码量学习体会 1.2.2学习体会     因为在暑假时候没有对c语言进行学习,没太关注一些学习资料,一些教学视频也没看,感觉对c语言是陌生的,刚开课的时候自 ...

  3. git删除未监视的文件

    新增的文件使用git status查看会提示Untracked files,如果想要删除Untracked files,可以使用如下命令: git clean -f # 删除Untracked fil ...

  4. PHP设计超级好用的文件上传处理类一 (37)

    <?php class FileUpload { private $filepath; //指定上传文件保存的路径 private $allowtype=array('gif', 'jpg', ...

  5. “全栈2019”Java多线程第十四章:线程与堆栈详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  6. Android实用代码片段

    有时候,需要一些小的功能,找到以后,就把它贴到了博客下面,作为留言,查找起来很不方便,所以就整理一下,方便自己和他人. 一.  获取系统版本号: 1 PackageInfo info = this.g ...

  7. Spring Boot入门教程(1)

    Spring Boot入门教程(1) 本文将使用Spring Boot一步步搭建一个简单的Web项目来帮助你快速上手. 将要用到的工具 JDK 8 IntelliJ IDEA(Ultimate Edi ...

  8. SQL Server——存储过程(Stored Procedure)、事物、触发器

    存储过程(proc 或 procedure) 存储过程(Stored Procedure),计算机用语,是一组为了完成特定功能的SQL语句集,是利用SQL Server所提供的Transact-SQL ...

  9. mysql导入大批量数据出现MySQL server has gone away的解决方法

    因工作需要,需要导入一个200M左右的sql到user库 执行命令 mysql> use user Database changed mysql> source /tmp/user.sql ...

  10. appium安装与部署

    前提: ①:appium属于C/S架构,代码写在Client端 ②:本章所说的部署讲的是Android设备下的Appium安装与部署 ③:Appium Client的环境是针对python3的 App ...