Fachgebiet Software Engineering Übersicht © 22.01.2014 Albert Zündorf, Kassel University Compilerbau und Reverse Engineering m Vorlesung im Wintersemester.

Slides:



Advertisements
Ähnliche Präsentationen
Kapitel 4 Syntaktische Analyse: LR Parsing.
Advertisements

Parsing regulärer Ausdrücke
Vorlesung 2 Rechnerarchitektur Universität Bielefeld – Technische Fakultät AG Rechnernetze und verteilte Systeme Peter B. Ladkin
Vorlesung 3: Verschiedenes Universität Bielefeld – Technische Fakultät AG Rechnernetze und verteilte Systeme Peter B. Ladkin
Rechnerarchitektur Vorlesung 2 Peter B. Ladkin
Programmiermethodik SS 07 Prof. Albert Zündorf
Programmiermethodik SS2009 © 2009 Albert Zündorf, University of Kassel 1 Gliederung 1. Einführung 2. Objektdiagramme zur Analyse von Beispielen 3. Methodenentwurf.
3. Klassendiagramme in Java implementieren
Programmiermethodik SS2007 © 2007 Albert Zündorf, University of Kassel 1 5. Test-First Prinzip Gliederung: 1. Einführung 2. Objektdiagramme zur Analyse.
Programmiermethodik SS 09 Prof. Albert Zündorf Fachgebiet für Software Engineering Wilhelmshöher Allee Kassel (Raum 1339 im Altbau)
3. Analyse Gliederung: Einführung Anforderungsdefinition
Programmiermethodik SS2007 © 2007 Albert Zündorf, University of Kassel 1 6. Story Driven Modeling Gliederung: 1. Einführung 2. Objektdiagramme zur Analyse.
Software Engineering Seminar Metamodellierung
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Software Engineering I m Vorlesung im Wintersemester 2008/09 m.
Reservierungs Datenbank
Programmiermethodik SS2006 © 2005 Albert Zündorf, University of Kassel 1 6. Tipps, Tricks, Idiome Gliederung: 1. Einführung 2. Anforderungsdefinition 3.
Programmiermethodik SS2006 © 2005 Albert Zündorf, University of Kassel 1 Objektorientierte Vererbung Student erbt von Person: extensional: Menge der Studenten.
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Projektplan: m : Anforderungsanalyse Dokument m :
Projektplan: Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University.
Tätigkeiten bei der Softwareentwicklung
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Software Engineering I m Vorlesung im Wintersemester 2007/08 m.
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Projektplan:
1 Reverse Engineering WS 07 / 08 A. Zündorf. Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University 2 Organisatorisches.
Programmiermethodik SS2007 © 2007 Albert Zündorf, University of Kassel 1 5. Test-First Prinzip Gliederung: 1. Einführung 2. Objektdiagramme zur Analyse.
A. Zündorf, SE Group Reverse Engineering K2 1 Übersicht 1.Quelltextanalyse mit regulären Ausdrücken 2.Compilertechniken 3.Prozessanalyse 4.Dynamische Analyse.
A. Zündorf, SE Group Reverse Engineering K2 1 Übersicht 1.Quelltextanalyse mit regulären Ausdrücken 2.Compilertechniken 3.Prozessanalyse 4.Dynamische Analyse.
A. Zündorf, SE Group Reverse Engineering K2 1 Ziele Heute Compilerbau Nachlese Ausnutzung von Laufzeittypinformation.
Projektmanagement Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University.
A. Zündorf, SE Group Reverse Engineering K2 1 Ziele Heute Compilerbau Nachlese Ausnutzung von Laufzeittypinformation.
Wasserfallmodel Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University.
Teamorganisation: Versionsverwaltung
Projektplan: Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University.
Projektplan: Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University.
Software Engineering I
Model Driven Engineering SS 10 Prof. Albert Zündorf Fachgebiet für Software Engineering Wilhelmshöher Allee Kassel (Raum 1339)
Model Driven Engineering SS 10 Prof. Albert Zündorf Fachgebiet für Software Engineering Wilhelmshöher Allee Kassel (Raum 1339)
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Compilerbau und Reverse Engineering m Vorlesung im Wintersemester.
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Test Summary: m ein Fehler pro Tag m Test First m Funktionstests.
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Compilerbau und Reverse Engineering m Vorlesung im Wintersemester.
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Software Engineering I m Vorlesung im Wintersemester 2010/11 m.
Programmiermethodik SS2009 © 2009 Albert Zündorf, University of Kassel 1 Gliederung 1. Einführung 2. Objektdiagramme zur Analyse von Beispielen 3. Methodenentwurf.
Model Driven Engineering SS 10 Prof. Albert Zündorf Fachgebiet für Software Engineering Wilhelmshöher Allee Kassel (Raum 1339)
Programmiermethodik SS 10 Prof. Albert Zündorf
Model Driven Engineering SS 10 Prof. Albert Zündorf Fachgebiet für Software Engineering Wilhelmshöher Allee Kassel (Raum 1339)
Programmiermethodik SS2010 © 2010 Albert Zündorf, University of Kassel 1 Gesamtvorgehen 1. Textuelle Szenarios 2. Objektdiagramme 3. Klassendiagramm 4.
Universität Karlsruhe (TH) © 2008 Univ,Karlsruhe, IPD, Prof. LockemannDBI 0 Datenbankimplementierung und -tuning Einführung.
1 Vorlesung 3 Verschiedenes Peter B. Ladkin
LL(1) Grammatiken Simple LL(1) ohne ε-Regeln verschiedene Produktionen, so gilt LL(1) ohne ε-Regeln verschiedene Produktionen, so gilt LL(1) mit ε-Regeln.
Zeitplanerstellung ACHTUNG:
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Software Engineering I m Vorlesung im Sommersemester 2012 m Prof.
Programmiermethodik SS2007 © 2007 Albert Zündorf, University of Kassel 1 5. Test-First Prinzip Gliederung: 1. Einführung 2. Objektdiagramme zur Analyse.
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Compilerbau und Reverse Engineering m Vorlesung im Wintersemester.
Programmiermethodik SS2007 © 2007 Albert Zündorf, University of Kassel 1 5. Test-First Prinzip Gliederung: 1. Einführung 2. Objektdiagramme zur Analyse.
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Client Architecture Data Model GUI KI Socket Connection.
Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Test Summary: m ein Fehler pro Tag m Test First m Funktionstests.
Model Driven Engineering SS 10 Prof. Albert Zündorf Fachgebiet für Software Engineering Wilhelmshöher Allee Kassel (Raum 1339)
Programmiersprachen II Integration verschiedener Datenstrukturen
Einführung in die Informatik für Naturwissenschaftler und Ingenieure
Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fakultät.
Computerorientierte Physik VORLESUNG und Übungen Vorlesung Zeit: Mo., – Uhr Ort: Hörsaal 5.01, Institut für Physik, Universitätsplatz 5, A-8010.
Eclipse-Entwicklungsumgebung
Programmieren in Assembler
Rechnerarchitekturen
1 Albert-Ludwigs-Universität Freiburg Rechnernetze und Telematik Prof. Dr. Christian Schindelhauer Informatik III Christian Schindelhauer Wintersemester.
Stadt- und Regionalsoziologie (S) : Einführung
Lehrstuhl für Informatik 3 - D. Fey Vorlesung GRa - SS , Folie 1 Beispiel Stack-Architektur.
Vom HW-Automaten zum Prozessor
מבוא למערכות מחשב ואסמבלי
Test Summary: ein Fehler pro Tag Test First
Software Engineering 2 – Konstruktion interaktiver (CASE) Tools
 Präsentation transkript:

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Compilerbau und Reverse Engineering m Vorlesung im Wintersemester 2008/09 m Prof. Albert Zündorf m Betreuer: Johannes Spohr, et. al. m Fachgebiet für Software Engineering

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Organisatorisches Umfang: 4 SWS teils Vorlesungen teils Übungen Übungsbetreuung: Johannes Spohr Ort und Zeit: Freitag 14: :00 Raum 1340 Beginn: Freitag, den Prüfung: Projektarbeit / Hausaufgaben jeder einzeln wird nur einmal im Jahr angeboten Folienskript, Unterlagen, Aufgabenstellungen: meist einen Tag in voraus.

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Inhalte und Lernziele: m Lesen und Verarbeiten strukturierter Texte m Daten m Programme m Rekursiverabstiegscompiler m Compilercompiler m Codegenerierung m Codecompletion m Codeanalyse m Refactorings m …

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Literatur m m Compilerbau, 2 Tle., Tl.1 von Alfred V. Aho, Ravi Sethi, und Jeffrey D. Ullman von Oldenbourg (Taschenbuch - Dezember 1999)Preis:EUR 34,80 Compilerbau, 2 Tle., Tl.1

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Scanning

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Scanning

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Code Generation m Registermaschinen m Maschinencode / Assembler m Stackmaschinen m BCEL

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Registermaschinen ALU OPCode Decoder AdderMultiplier LogicOpsStoreOps JumpOps PC ACU FP R1..8 Memory Address Decoder

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University OPCode Decoder Adder Addierbefehl & =0 &

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Maschinencode Registermaschine m Arithmetisch, Logisch, Speicher, Sprung, … m OpCode plus 1 oder 2 Operanden m Rechenbefehle nur auf Registern m Speicherbefehle: Memory Register

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Stackmaschinen ALU OPCode Decoder AdderMultiplier LogicOpsStoreOps JumpOps PC ACU FP R1..8 Memory Address Decoder Stack

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Maschinencode Stackmaschine m Arithmetisch, Logisch, Speicher, Sprung, … m OpCode plus 1 oder 2 Operanden m Rechenbefehle auf Stack m Speicherbefehle: Memory Stack m load 0, load 8, add, store 12

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Java Byte Code für eine Klasse

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University BCELifier m Beispiel in Java schreiben m Compilieren m mit BCELifier "Creator" Klasse generien m anschauen

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University if

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University

while

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University funcDecl pi() { } pi()

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Scopes

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Procedure Call Stack

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University

Tabellengesteuertes Parsen Beispielgrammatik: E ::= T ['+' T]*E ::= T E' E' ::= + T E' | T ::= F ['*' F]*T ::= F T' T' ::= * F T' | F ::= n | '(' E ')'

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Parsertabelle +*()n$ EE::=TE' E'E'::=+TE' E'::= TT::=FT' T' T'::= T'::=*FT' T'::= FF::=(E)F::=n

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Algorithmus while Stack nicht leer if top == currentToken pop nextToken() else rule := M[top, currentToken] pop push (lhs(rule)) print rule

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Ablauf: StackEingabeAusgabe $n + n * n $

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Ablauf: StackEingabeAusgabe

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Konstruktion: First und Follow First ( ) Menge aller Terminale mit denen beginnen kann First (a) {a} X ::= First ( X ) += X ::= A B C D First ( X ) += First ( A ) if ( First (A) ) First ( X ) += First (B) …

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Konstruktion: First und Follow E ::= T E'First (E) = {} E' ::= + T E' | First (E') = {} T ::= F T'First (T) = {} T' ::= * F T' | First (T') = {} F ::= n | '(' E ')'First (F) = {}

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Konstruktion: First und Follow Follow (X)alle Terminale die auf X folgen können SFollow (S) += $ A ::= B Follow (B) += First ( ) - if ( First ( ) ) Follow (B) += Follow (A) A ::= BFollow (B) += Follow (A)

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Konstruktion: First und Follow E ::= T E' Follow (E) = {} E' ::= + T E' | Follow (E') = {} T ::= F T' Follow (T) = {} T' ::= * F T' | Follow (T') = {} F ::= n | '(' E ')' Follow (F) = {}

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Tabellenkonstruktion for_all A ::= for_all a First ( ) M[A,a] += A ::= if First ( ) for_all b Follow (A) M[A,b] += A ::= if $ Follow (A) M[A,$] += A ::=

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Tabellenkonstruktion E ::= T E' E' ::= + T E' | T ::= F T' T' ::= * F T' | F ::= n | '(' E ')' +*()n$ E E' T T' F

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Compiler Compiler: Antlr V3

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University Model Driven XXX

Fachgebiet Software Engineering Übersicht © Albert Zündorf, Kassel University