Programmierparadigmen und Sprachen
|
|
- Sigrid Meissner
- vor 5 Jahren
- Abrufe
Transkript
1 Fakultät Informatik Institut für Software- und Multimediatechnik Professur Softwaretechnologie Programmierparadigmen und Sprachen Scala Paul Henke Dresden,
2 Gliederung Hello World Scala? Features Demo TU Dresden, Scala Folie 2 von 21
3 Hello World object HelloWorld { def main(args: Array[String]) { println("hello, world!") TU Dresden, Scala Folie 3 von 21
4 Scala? Scalable Language wird von Martin Odersky (EPFL, Schweiz) seit 2001 entworfen und entwickelt statisch getypte Multiparadigmensprache verknüpft Objektorientierte Programmierung mit Funktionaler läuft auf der JVM sowie in.net vollständig in die jeweilige Umgebung integriert aktuelle Version TU Dresden, Scala Folie 4 von 21
5 Features Klassen Einfach Vererbung Mixins (durch Traits) Alles wird als Objekt behandelt Type Inference XML als nativer Datentyp Schönfinkeln Partial Application First Class und Higher Order Functions Closures Structural Typing Pattern Matching Tupel Actors und Messages TU Dresden, Scala Folie 5 von 21
6 Syntax Semikolons unnötig keine Operatoren Methoden können Infix geschrieben werden Klammern können bei Methoden mit maximal einem Parameter weggelassen werden statt 1.+(2) geeignet für Domain Specific Languages (durch viele Freiheiten in der Syntax) z.b. ScalaTest Framework collection should contain element 1.0 result should be >= 0 TU Dresden, Scala Folie 6 von 21
7 Klassenhierarchie TU Dresden, Scala Folie 7 von 21
8 Klassen class Person(name:String, age:int) { def Name:String = name def Age:Int = age var city:string = "" def sayhi { println("hi") override def tostring():string = name + " (" + age + ")" var p:person = new Person("Horst", 20) println(p.name) // Horst println(p) // Horst (20) p.sayhi() p.city = "Dresden" // Hi TU Dresden, Scala Folie 8 von 21
9 Singletons Objects es gibt keinen static Modifier object Math { def PI:Double = def pow(b:long,e:long) = { def sin(a:double) = { def cos(a:double) = { /*... */ println(math.pow(2,8)) // 256 TU Dresden, Scala Folie 9 von 21
10 Type Inference auf Typangaben kann ich den meisten Fällen verzichtet werden Variablen var x = 5 var y = "Scala x = "ist toll" // x:int // y:string // type mismatch var z = x * 10 // z:int Rückgabetyp von Funktionen def add(x:float, y:float) = { x+y // add(float, Float):Float TU Dresden, Scala Folie 10 von 21
11 Traits abstrakter Typ ähnlich wie Java Interfaces bzw abstrakte Klassen Mixin Composition -> Mehrfach Vererbung trait Occupation { var occupation = "" override def tostring = super.tostring + "(" + occupation + ")" trait Status { var status = "" override def tostring = super.tostring + "(" + status + ")" TU Dresden, Scala Folie 11 von 21
12 Traits class BetterPerson(n:String, a:int) extends Person(n,a) with Occupation with Status val bp = new BetterPerson("Alice", " 25) bp.occupation = "Student"; bp.status = "Married" println(bp) // Alice (25)(Student)(Married) TU Dresden, Scala Folie 12 von 21
13 Traits trait Ord[T] { def < (that: T): Boolean def <=(that: T): Boolean = (this < that) (this == that) def > (that: T): Boolean =!(this <= that) def >=(that: T): Boolean =!(this < that) class Rational(n: Int, d: Int) extends Ord[Rational] { /* */ def <(that: Rational) = numer * denom > that.numer * that.denom var r1 = new Rational(7,5) var r2 = new Rational(13,7) println(r1 > r2) // true TU Dresden, Scala Folie 13 von 21
14 First Class Functions Funktionen sind auch Objekte haben einen Typ können Variablen zugewiesen werden val printhi:() => Unit = () => println("hi") printhi() // "hi" val return5:() => Int = () => 5 return5() // 5 val add:(int,int) => Int = (x,y) => x+y add(7,3) // 10 TU Dresden, Scala Folie 14 von 21
15 Higher Order Functions Funktionen die andere Funktionen als Parameter nehmen oder zurück geben def exists[t](list:list[t], f:t => Boolean ):Boolean = { for(item <- list) if(f(item)) return true return false val l = List(2,3,5,7,8,10) println(exists(l, n => n % 4 == 0)) println(exists(l, n => n < 0)) println(exists(plist, p => p.age > 18)) // true // false // true TU Dresden, Scala Folie 15 von 21
16 Closures Funktionen die auf Variablen zugreifen können die in ihrem Scope liegen def findpersonbyname(name:string):person = { personlist.filter(p => p.name == name) var x = 3 val printx: () => Unit = () => println(x) printx() // 3 x = 23 printx() // 23 TU Dresden, Scala Folie 16 von 21
17 Tail Recursion def factorial(n:bigint):bigint = { if(n == 1) 1 else n * factorial(n-1) println(factorial(10)) // println(factorial(5000)) // StackOverflowError def factorial2(akk:bigint,n:bigint):bigint = { if(n == 1) akk else factorial2(akk*n,n-1) println(factorial2(1,5000)) // TU Dresden, Scala Folie 17 von 21
18 Currying ist die Umwandlung einer Funktion mit mehreren Argumenten in mehrere Funktionen mit je einem Argument def factorial3(akk:bigint)(n:bigint):bigint = { if(n == 1) akk else factorial2(akk*n n,n-1) println(factorial3(1)(7)) // 5400 Partial Application def fact = factorial3(1)_ println(fact(8)) // TU Dresden, Scala Folie 18 von 21
19 Pattern Matching def factorial4(akk:int, i:int):int = { i match { case 1 => akk case n => factorial2(akk*n, n-1) println(factorial4(1,9)) // def tup(exp:any) = { exp match { case (a,b) => println("matched:" + a + "," + b) case (a) => println("matched:" + a ) println(tup(5)) // Matched:5 println(tup(("bob",25))) // Matched:Bob,25 TU Dresden, Scala Folie 19 von 21
20 Quellen Offizielle Seite Scala by Example Scala Tutorial ScalaTest Framework A Weblog by Martin Odersky p// / g/ jp gg TU Dresden, Scala Folie 20 von 21
21 Fragen Fragen? TU Dresden, Scala Folie 21 von 21
Die Programmiersprache Scala
Veranstaltungsnummer: 18.163 Sommersemester 2008 Dozent: Prof. Dr. Heinz Züllighoven Betreuer: Dr. Axel Schmolitzky Die Programmiersprache Scala Simon Gerlach, Johannes Kuhlmann Ausgewählte Themen der
MehrPraktische Informatik 3: Funktionale Programmierung Vorlesung 13 vom : Scala Eine praktische Einführung
15:59:34 2019-01-22 1 [17] Praktische Informatik 3: Funktionale Programmierung Vorlesung 13 vom 22.01.19: Scala Eine praktische Einführung Christoph Lüth Universität Bremen Wintersemester 2018/19 PI3 WS
MehrPraktische Informatik 3: Funktionale Programmierung Vorlesung 13 vom : Scala Eine praktische Einführung
09:29:47 2017-01-25 1 [18] Praktische Informatik 3: Funktionale Programmierung Vorlesung 13 vom 24.01.17: Scala Eine praktische Einführung Christoph Lüth Universität Bremen Wintersemester 2016/17 PI3 WS
MehrScala: Klassen, Methoden und Objekte. von Simon Lerch
Scala: Klassen, Methoden und Objekte von Simon Lerch Überblick Methoden Klassen Objekte Basis Typen Prefixes Java's == vs. Scala's == Assoziativität von Operatoren Rich Wrapper 30.03.10 Klassen, Methoden
MehrAusdrücke in Scala. Funktionale Programmierung. Christoph Knabe FB VI
Ausdrücke in Scala Funktionale Programmierung Christoph Knabe FB VI 17.10.2014 Inhalt Einfache Ausdrücke Infix-Notation für Methodenaufruf Sonderzeichen in Bezeichnern Schlüsselwörter Konstanten Variablen
MehrVererbung und Traits
Vererbung und Kiermaier Ulrich FWP-Fach: Scala: Java-Nachfolger oder akademisches Experiment? 11.5.2010 Übersicht Aufbau nach dem Buch Programming in Scala von Martin Odersky, Lex Spoon, Bill Venners Vererbung
MehrProgrammieren in Java
Programmieren in Java Vorlesung 11: Generic Methods Prof. Dr. Peter Thiemann Albert-Ludwigs-Universität Freiburg, Germany SS 2017 Peter Thiemann (Univ. Freiburg) Programmieren in Java JAVA 1 / 15 Inhalt
MehrScala. Jan Kriesten AK Objekttechnologie Norddeutschland 12. April 2010
Scala Jan Kriesten AK Objekttechnologie Norddeutschland 12. April 2010 Vorstellung Internetagentur mit Standort Hamburg Web business seit 1995 Consulting, Training, Softwareentwicklung Systemadministration
MehrScala. Funktionale (Zustandslose) Objekte
Scala Funktionale (Zustandslose) Objekte Agenda Was sind Funktionale Objekte? veränderliche Objekte vs. unveränderliche Objekte Klassen Parameter Konstruktoren Private Member Methoden und Operatoren Overriding
MehrVarietékünstler Die Programmiersprache Scala. Jan Hermanns. www.sushi3003.de
Varietékünstler Die Programmiersprache Scala Jan Hermanns www.sushi3003.de Wer hat`s erfunden? Entwickelt von Martin Odersky an der EPFL Erstes Release 2003 Scala Überblick Interoperabilität mit Java Java-Bytecode
MehrScala & Lift. Ferenc Lajko 04.02.2010
Scala & Lift Ferenc Lajko 04.02.2010 Gliederung 1. Scala 1.1. Allgemein 1.2. Merkmale 1.3. Unterschiede zu Java 1.4. Code-Beispiel 1.5. Vorteile zu anderen Sprachen 2. Lift 2.1. Allgemein 2.2. Idee 2.3.
MehrScala LIGHTNING TALK 03
Scala LIGHTNING TALK 03 Agenda 1.Was ist Scala? 2.Hauptmerkmale von Scala 3.Bewertung 2 LT 03 - Scala Was ist Scala? Scala: scalable language l Forschungsprojekt zur Komponentenorientierung l Hypothese
MehrÜbergang von funktionaler zu OOP. Algorithmen und Datenstrukturen II 1
Übergang von funktionaler zu OOP Algorithmen und Datenstrukturen II 1 Imperative vs. funktionale Programmierung Plakativ lassen sich folgende Aussagen treffen: funktional: imperativ: Berechnung von Werten
Mehr(Building) Flexible Functional Programming Interfaces. Von Amos Treiber
(Building) Flexible Functional Programming Interfaces Von Amos Treiber Gliederung Funktionale Programmierung Einführung Aspekte Vergleich: Funktional vs Imperativ Bending the language towards the problem
MehrVorlesung Objektorientierte Programmierung WS 2013/2014 / Folie 620
OOP-6.20 / FP-9.3a 6.4 Scala: objektorientierte und funktionale Sprache Scala: Objektorientierte Sprache (wie Java, in kompakterer Notation) ergänzt um funktionale Konstrukte (wie in SML); objektorientiertes
MehrInstitut für Programmierung und Reaktive Systeme. Java 7. Markus Reschke
Institut für Programmierung und Reaktive Systeme Java 7 Markus Reschke 14.10.2014 Vererbung in Java Vererbung ermöglicht es, Klassen zu spezialisieren Wiederverwendung vorhandener Klassen Kindsklasse erhält
MehrSeminar Scala SS2010, Einführung. R. Schiedermeier Fakultät 07 für Informatik und Mathematik
Seminar Scala SS2010, Einführung R. Schiedermeier Fakultät 07 für Informatik und Mathematik Themen Ausführen von Scala-Code Werte und Variablen Methoden Typen 22.04.10 Seminar Scala, Einführung 2 Übersetzen
MehrFunktionale Programmierung. Frank Adler
F# Funktionale Programmierung Frank Adler Was ist funktionale Programmierung Funktionale Programmierung ist die Komposition von Funktionen. Funktionale Konzepte First-Class Functions Higher-Order Functions
MehrEinleitung Nutzung der Standard Kontrollstrukturen if else, for, do while, while, match, try catch Spezielle Kontrollstrukturen
Scala Java-Nachfolger oder akademisches Experiment? KONTROLLABSTRAKTION (NEUE KONTROLLSTRUKTUREN) Einleitung Nutzung der Standard Kontrollstrukturen if else, for, do while, while, match, try catch Spezielle
MehrMethoden und Funktionen in Scala
Methoden und Funktionen in Scala Kapitel 11 und 12 des Buches 1 Jede Methode hat einen Typ Für die folgende Methode def square(v: Int) = v*v erhalten wir von der Scala-Shell die Rückmeldung square: (Int)Int
MehrKopieren und Vergleichen
Softwareentwicklung II (IB) Kopieren und Vergleichen Fakultät für Informatik und Mathematik Hochschule München Letzte Änderung: 24.05.2018 13:24 Inhaltsverzeichnis Kopie eines Objektes................................
MehrAlgorithmen und Datenstrukturen
Algorithmen und Datenstrukturen Tafelübung 03 Vererbung, Polymorphie, Sichtbarkeit, Interfaces Clemens Lang T2 11. Mai 2010 14:00 16:00, 00.152 Tafelübung zu AuD 1/26 Klassen und Objekte Klassen und Objekte
MehrAnwendung (2. Versuch:-) Entkopplung der Locks
Gut gemeint aber leider fehlerhaft... Jeder Producer benötigt zwei Locks gleichzeitig, um zu produzieren: 1. dasjenige für den Puffer; 2. dasjenige für einen Semaphor. Musser fürden Semaphor einwait()
MehrWeb-Techniken Einführung in JavaScript
Web-Techniken Einführung in JavaScript Prof. Dr. Axel Böttcher Winter 2012/13 15. September 2012 Ausführung von JavaScript Variante 1: Ausführung im Browser durch direktes Einbetten: 1 2
MehrGliederung der Folien
1 Gliederung der Folien 1. Einführung 1.1. Gliederung 1.2. Literatur 1.3. Einstieg in Java 1.3.1. Geschichte von Java 1.3.2. Hello World 1.3.3. Übersetzen eines Java-Programms 1.4. Die Entwicklungsumgebung
MehrDatenstrukturen / Container in Java
Datenstrukturen / Container in Java Mathematik / Algebraischer Datentyp / Containerklassen Enum-Klassen Arrays (Felder) = elementare Container Algorithmen mit Arrays Prof. Dr. E. Ehses, 2014 1 Mathematik
MehrWas du ererbt von Deinen Vätern hast, erwirb es, um es zu besitzen. J. W. v. Goethe.
Was du ererbt von Deinen Vätern hast, erwirb es, um es zu besitzen. J. W. v. Goethe http://www.zitate-online.de/autor/goethe-johann-wolfgang-von/ http://www.weimar-lese.de/files_weimar_lese/johann_wolfgang_von_goethe_bearbeitet_von_andreas_werner.jpg
MehrProgrammieren in Scala. 17. Juni 2013 G. Schellhorn, D. Haneberg: Formale Methoden im Software Engineering 232 / 300
Programmieren in Scala 17. Juni 2013 G. Schellhorn, D. Haneberg: Formale Methoden im Software Engineering 232 / 300 Motivation Aus Sicht unseres Sotwaretechnik-Lehrstuhls: Scala ist eine der derzeit modernsten
Mehr1 Klassen und Objekte
1 Klassen und Objekte Datentyp - Spezifikation des Typs von Datenobjekten Datenstruktur - logische Ordnung von Elementen eines Datentyps - zur (effizienten) Speicherung, Verwaltung, Zugriff - auf die Elemente
MehrII.4.5 Generische Datentypen - 1 -
1. Unterklassen und Vererbung 2. Abstrakte Klassen und Interfaces 3. Modularität und Pakete 4. Ausnahmen (Exceptions) 5. Generische Datentypen 6. Collections II.4.5 Generische Datentypen - 1 - Ähnliche
MehrAlles außer Java! JVM-Sprachen sagen Happy Birthday
JUGS 20 Jahre Java Alles außer Java! JVM-Sprachen sagen Happy Birthday Jan-Paul Buchwald BeOne Stuttgart GmbH 15 Jahre JVM Sprachen Jython Rhino 2001: JRuby Groovy Scala 2007: Clojure 1992 2002 2012 1992:
MehrOCP Java SE 8. Lambda
OCP Java SE 8 Lambda Lambda-Ausdruck sieht ähnlich wie eine Deklaration einer Methode ohne Name und Ergebnistyp aus (a, b) -> b.compareto(a) Lambda Vor Java 8 Ausführbarer Programmcode ( Verhalten ) nur
MehrJava 8. Johannes Hellrich, Erik Fäßler. Oberseminar
Java 8 Johannes Hellrich, Erik Fäßler Oberseminar 29.6.2017 Quellen https://github.com/winterbe/java8-tutorial http://www.lambdafaq.org https://github.com/jooq Größte Änderung: Funktionale Programmierung
MehrII.4.2 Abstrakte Klassen und Interfaces - 1 -
1. Unterklassen und Vererbung 2. Abstrakte Klassen und Interfaces 3. Modularität und Pakete 4. Ausnahmen (Exceptions) 5. Generische Datentypen 6. Collections II.4.2 Abstrakte Klassen und Interfaces - 1
MehrOCP Java SE 8. Lambda
OCP Java SE 8 Lambda Lambda-Ausdruck sieht ähnlich wie eine Deklaration einer Methode ohne Name und Ergebnistyp aus (a, b) -> b.compareto(a) Lambda Vor Java 8 Ausführbarer Programmcode ( Verhalten ) nur
MehrMethoden (fortgeschritten) in C# - 1
Methoden (fortgeschritten) in C# - 1 Marc Satkowski 20. November 2016 C# Kurs Gliederung 1. Opertatoren Überladung 2. delegate 3. Anonyme Methoden delegate Lamda Ausdruck-Lamdas Anweisung-Lamdas Variablenbereich
MehrGrundlegende Datentypen
Funktionale Programmierung Grundlegende Datentypen Fakultät für Informatik und Mathematik Hochschule München Letzte Änderung: 14.11.2017 15:37 Inhaltsverzeichnis Typen........................................
MehrGliederung. n Teil I: Einleitung und Grundbegriffe. n Teil II: Imperative und objektorientierte Programmierung
Gliederung n Teil I: Einleitung und Grundbegriffe l 1. Organisatorisches l 2. Grundlagen von Programmiersprachen n Teil II: Imperative und objektorientierte Programmierung l 1. Grundelemente der Programmierung
MehrInformatik II Übung 06. Benjamin Hepp 5 April 2017
Informatik II Übung 06 Benjamin Hepp benjamin.hepp@inf.ethz.ch 5 April 2017 Nachbesprechung U5 5 April 2017 Informatik II - Übung 01 2 Nachbesprechung U5 1. Einfach verkettete Listen Keine Probleme 2.
MehrAlgorithmen und Datenstrukturen II
Algorithmen und Datenstrukturen II AG Praktische Informatik Technische Fakultät Vorlesung Sommer 2009 Teil I Übergang von funktionaler zu OOP Imperative vs. funktionale Programmierung Plakativ lassen sich
MehrKopieren und Vergleichen
Kopieren und Vergleichen Softwareentwicklung II (IB) Prof. Dr. Oliver Braun Letzte Änderung: 24.05.2018 13:24 Kopieren und Vergleichen 1/26 Kopie eines Objektes (1/4) Erster Ansatz zum Duplizieren eines
MehrObjektorientierte Programmierung. Kapitel 22: Aufzählungstypen (Enumeration Types)
Stefan Brass: OOP (Java), 22. Aufzählungstypen 1/20 Objektorientierte Programmierung Kapitel 22: Aufzählungstypen (Enumeration Types) Stefan Brass Martin-Luther-Universität Halle-Wittenberg Wintersemester
MehrÜbergang von funktionaler zu OOP. Algorithmen und Datenstrukturen II 1
Übergang von funktionaler zu OOP Algorithmen und Datenstrukturen II 1 Imperative vs. funktionale Programmierung Plakativ lassen sich folgende Aussagen treffen: funktional: imperativ: Berechnung von Werten
MehrDie Definition eines Typen kann rekursiv sein, d.h. Typ-Konstruktoren dürfen Elemente des zu definierenden Typ erhalten.
4.5.5 Rekursive Typen Die Definition eines Typen kann rekursiv sein, d.h. Typ-Konstruktoren dürfen Elemente des zu definierenden Typ erhalten. datatype IntList = Nil Cons o f ( i n t IntList ) ; Damit
MehrKapitel 9. Programmierkurs. Attribute von Klassen, Methoden und Variablen. 9.1 Attribute von Klassen, Methoden und Variablen
Kapitel 9 Programmierkurs Birgit Engels Anna Schulze Zentrum für Angewandte Informatik Köln Objektorientierte Programmierung Attribute von Klassen, Methoden und Variablen Interfaces WS 07/08 1/ 18 2/ 18
MehrVorkurs Informatik WiSe 15/16
Java 7 Dr. Werner Struckmann / Stephan Mielke, Jakob Garbe, 21.10.2015 Technische Universität Braunschweig, IPS Überblick OO in Java Vererbung Abstrakte Klassen und Interfaces 21.10.2015 Dr. Werner Struckmann
MehrProgrammierkurs Java
Programmierkurs Java Java Generics und Java API (1/2) Prof. Dr. Stefan Fischer Institut für Telematik, Universität zu Lübeck https://www.itm.uni-luebeck.de/people/fischer Datenstrukturen In vielen Sprachen
MehrII.4.1 Unterklassen und Vererbung - 1 -
1. Grundelemente der Programmierung 2. Objekte, Klassen und Methoden 3. Rekursion und dynamische Datenstrukturen 4. Erweiterung von Klassen und fortgeschrittene Konzepte II.4.1 Unterklassen und Vererbung
MehrUnveränderliche Klassen
Softwareentwicklung II (IB) Unveränderliche Klassen Fakultät für Informatik und Mathematik Hochschule München Letzte Änderung: 02.03.2018 12:40 Inhaltsverzeichnis Idee.........................................
MehrUniversität Karlsruhe (TH)
Universität Karlsruhe (TH) Lehrstuhl für Programmierparadigmen Fortgeschr. Objektorientierung SS 2009 http://pp.info.uni-karlsruhe.de/ Dozent: Prof. Dr.-Ing. G. Snelting snelting@ipd.info.uni-karlsruhe.de
MehrJavakurs 12: Methoden
Javakurs 12: Methoden Johannes Heinemann basierend auf der Vorlage von Mario Bodemann und Sebastian Dyroff Sadik Hasanovic Technische Universität Berlin 6. März 2012 This work is licensed under the Creative
MehrJAVA 05: Objektorientierte Konzepte
Lernkartenkurs JAVA 05: Objektorientierte Konzepte panitz Zusammenfassung Dieser Kurs beschäftigt sich mit Grundkonzepten der objektorientierten Programmierung. Was sind Klassen und Objekte? Wie sehen
MehrSoftwareentwicklung II (IB) Methoden. Prof. Dr. Oliver Braun. Fakultät für Informatik und Mathematik Hochschule München
Softwareentwicklung II (IB) Methoden Fakultät für Informatik und Mathematik Hochschule München Letzte Änderung: 05.04.2018 17:44 Inhaltsverzeichnis Was Sie bereits wissen müssen: Siehe Softwareentwicklung
MehrInstitut für Programmierung und Reaktive Systeme. Java 6. Markus Reschke
Institut für Programmierung und Reaktive Systeme Java 6 Markus Reschke 13.10.2014 OOP Objekte = Verhalten (durch Methoden) + Daten (durch Attribute) Klassen = Baupläne für Objekte Kapselung von Programmteilen
MehrFunktionale Programmierung Grundlegende Datentypen
Grundlegende Datentypen Prof. Dr. Oliver Braun Fakultät für Informatik und Mathematik Hochschule München Letzte Änderung: 06.11.2017 16:45 Inhaltsverzeichnis Typen........................................
MehrGrundlegende Datentypen
Grundlegende Datentypen Funktionale Programmierung Prof. Dr. Oliver Braun Letzte Änderung: 22.10.2018 10:53 Grundlegende Datentypen 1/21 Typen in Haskell ist alles streng typisiert Haskell verfügt über
Mehrfloat: Fließkommazahl nach IEEE 754 Standard mit 32 bit
Primitive Datentypen Fließkommazahlen float: Fließkommazahl nach IEEE 754 Standard mit 32 bit Vorzeichen Exponent 8 bit Mantisse 23 bit double: Fließkommazahl nach IEEE 754 Standard mit 64 bit Vorzeichen
MehrEINFÜHRUNG IN DIE PROGRAMMIERUNG
EINFÜHRUNG IN DIE PROGRAMMIERUNG GRUNDLAGEN Tobias Witt!! 24.03.2014 ORGANISATORISCHES 09:00-10:30! Täglich Übungen zur Vertiefung! Laptop hier nicht erforderlich! Linux, OS X! Freitag: http://hhu-fscs.de/linux-install-party/
MehrValidation und Quick Fixing mit Xtend. 3. Dezember 2014
Validation und Quick Fixing mit Xtend 3. Dezember 2014 175 Überblick Tuning der Xtext-generierten Editoren Validierung mit OCL auf der abstrakten Syntax mit Xtend auf der konkreten Syntax Quick Fixes mit
MehrJavakurs FSS Lehrstuhl Stuckenschmidt. Tag 3 - Objektorientierung
Javakurs FSS 2012 Lehrstuhl Stuckenschmidt Tag 3 - Objektorientierung Warum Objektorientierung Daten und Funktionen möglichst eng koppeln und nach außen kapseln Komplexität der Software besser modellieren
MehrScala Tutorial für Java Programmierer
Scala Tutorial für Java Programmierer Version 1.3 5. März 2011 Michel Schinz, Philipp Haller Übersetzung Ulrich Jordan PROGRAMMING METHODS LABORATORY EPFL SWITZERLAND 2 1 Einleitung Dieses Dokument ist
MehrFunktionale Programmierung ALP I. Funktionen höherer Ordnung SS Prof. Dr. Margarita Esponda. Prof. Dr. Margarita Esponda
ALP I SS 2011 Funktionstypen Funktionen haben einen Datentyp, der folgende allgemeine Form hat: functionname :: T 1 -> T 2, wobei T 1, T 2 wiederum beliebige Datentypen sind Beispiel: T 1 T 2 Der Datentyp
Mehrstring: Beispiele: Test, test, `Seitentitel: ${document.title}`
JS Crashkurs Einige JavaScript spezifische Dinge zusammengefasst. Datentypen Javascript kennt folgende primitiven Datentypen: undefined number: Beispiele: 1 1.0.0 1. 0x1 1e0 boolean: true oder false string:
MehrAlgorithmen und Datenstrukturen II
Algorithmen und Datenstrukturen II in JAVA D. Rösner Institut für Wissens- und Sprachverarbeitung Fakultät für Informatik Otto-von-Guericke Universität Magdeburg Sommer 2009, 31. März 2009, c 2009 D.Rösner
Mehr4. Vererbung Die Klasse Object. Die Klasse Object
4. Vererbung Die Klasse Object Die Klasse Object Alle Klassen ohne explizit deklarierte Superklasse haben die Klasse Object als Superklasse. Object gehört zum Paket java.lang. Object verfügt über einige
MehrSoftware Entwicklung 1
Software Entwicklung 1 Annette Bieniusa AG Softech FB Informatik TU Kaiserslautern Klassenattribute und -methoden Bieniusa Software Entwicklung 1 2/ 23 Beispiel: Klassenattribute I class Uebungsgruppe
MehrGrundlegende Datentypen
Grundlegende Datentypen (Funktionale Programmierung) Prof. Dr. Oliver Braun Letzte Änderung: 18.03.2018 21:08 Grundlegende Datentypen 1/16 Typen in Haskell ist alles streng typisiert Haskell verfügt über
MehrIT I: Heute. Nachbetrachtung Wissensüberprüfung. Einführung Vererbung. Roboter in becker.robots. Filialenbelieferung 4.11.
IT I: Heute Nachbetrachtung Wissensüberprüfung Einführung Vererbung Roboter in becker.robots Filialenbelieferung 4.11.2014 IT I - VO 4 1 Organisatorisches Tutorium am Mi, 12.11. schon um 11 Uhr (bis 12:30).
Mehr12 Abstrakte Klassen, finale Klassen und Interfaces
12 Abstrakte Klassen, finale Klassen und Interfaces Eine abstrakte Objekt-Methode ist eine Methode, für die keine Implementierung bereit gestellt wird. Eine Klasse, die abstrakte Objekt-Methoden enthält,
MehrKonzepte von Programmiersprachen
Konzepte von Programmiersprachen Kapitel 3: Ausdrücke Phillip Heidegger Universität Freiburg, Deutschland SS 2009 Phillip Heidegger (Univ. Freiburg) Konzepte von Programmiersprachen KvP 1 / 17 Inhalt Let
MehrGenerische Datenstrukturen
Generische Datenstrukturen Prof. Dr. rer. nat. habil. Uwe Aßmann Lehrstuhl Softwaretechnologie Fakultät für Informatik TU Dresden Softwaretechnologie, Prof. Uwe Aßmann 1 2 Trends in der Softwareentwicklung
MehrFunktionale Programmierung
Funktionale Programmierung Definition Historie Motivation Die Programmiersprache Scala Einfache funktionale Programme Auswertung von Ausdrücken match.. case Prof. Dr. E. Ehses, Paradigmen der Programmierung.
MehrObjektorientierte Programmierung
Universität der Bundeswehr Fakultät für Informatik Institut 2 Priv.-Doz. Dr. Lothar Schmitz FT 2006 Übungsblatt 3 Lösungsvorschlag Objektorientierte Programmierung 08. 05. 2006 Lösung 8 (Java und UML-Klassendiagramm
MehrFunk%onale*Programmierung* op%mal*nutzen* Michael*Sperber*
Funk%onale*Programmierung* op%mal*nutzen* Michael*Sperber* * Individualso
MehrJava Methoden. Informatik 1 für Nebenfachstudierende Grundmodul. Kai-Steffen Hielscher Folienversion: 1. Februar 2017
Informatik 1 für Nebenfachstudierende Grundmodul Java Methoden Kai-Steffen Hielscher Folienversion: 1. Februar 2017 Informatik 7 Rechnernetze und Kommunikationssysteme Inhaltsübersicht Kapitel 3 - Java
MehrObjekt-Funktionale Programmierung. am Beispiel von SCALA. Thorsten Jolitz
Objekt-Funktionale Programmierung am Beispiel von SCALA Thorsten Jolitz 1. Auflage 2012 Inhaltsverzeichnis 1. Einleitung 1 1. Ausgangspunkt Imperative Programmierung 5 2. Elemente der Imperativen Programmierung
MehrMethoden. (Softwareentwicklung II (IB)) Prof. Dr. Oliver Braun. Letzte Änderung: :40. Methoden 1/44
Methoden (Softwareentwicklung II (IB)) Prof. Dr. Oliver Braun Letzte Änderung: 02.03.2018 12:40 Methoden 1/44 Was Sie bereits wissen müssen: Siehe Softwareentwicklung I (IB) Methoden 2/44 Überladen Methoden
MehrTECHNISCHE UNIVERSITÄT MÜNCHEN FAKULTÄT FÜR INFORMATIK
ECHNISCHE UNIVERSIÄ MÜNCHEN FAKULÄ FÜR INFORMAIK Lehrstuhl für Sprachen und Beschreibungsstrukturen WS 2007/2008 Praktikum Grundlagen der Programmierung Lösungsvorschläge zu Blatt 9 F. Forster,. Gawlitza,
MehrGroovy für Java Programmierer. 20. Juli Stefan Kolatzki
Groovy für Java Programmierer 20. Juli 2015 Stefan Kolatzki Übersicht Karriere bei LINEAS Groovy für Java Programmierer Closures Literale, Operatoren, Operatoren überladen Extensions Compilerverhalten
Mehr! 1. Unterklassen und Vererbung! 2. Abstrakte Klassen und Interfaces! 3. Modularität und Pakete. II.4.2 Abstrakte Klassen und Interfaces - 1 -
! 1. Unterklassen und Vererbung! 2. Abstrakte Klassen und Interfaces! 3. Modularität und Pakete II.4.2 Abstrakte Klassen und Interfaces - 1 - Ähnliche Programmteile public class Bruchelement { Bruch wert;
MehrKlausur: Java (Liste P)
Klausur: Java (Liste P) SS05 Erlaubte Hilfsmittel: Gebundene! Unterlagen (Skript mit Anmerkungen, eigene Mitschrift) und maximal ein Buch. Bitte keine losen Blätter. Lösung ist auf den Klausurbögen anzufertigen.
MehrMethoden und Wrapperklassen
Methoden und Wrapperklassen CoMa-Übung IV TU Berlin 06.11.2012 CoMa-Übung IV (TU Berlin) Methoden und Wrapperklassen 06.11.2012 1 / 24 Themen der Übung 1 Methoden 2 Wrapper-Klassen CoMa-Übung IV (TU Berlin)
MehrFunktionale Programmiersprachen
Funktionale Programmiersprachen An den Beispielen Haskell und Erlang Übersicht Programmiersprachen λ-kalkül Syntax, Definitionen Besonderheiten von funktionalen Programmiersprache, bzw. Haskell Objektorientierte
MehrJava Grundlagen 2 - OOP
Institut für Programmierung und Reaktive Systeme Java Grundlagen 2 - OOP Markus Reschke 20.08.2014 Eine kleine Geschichte 1 Spezifikation Es sollen Formen in einer GUI angezeigt werden: Ein Quadrat, ein
MehrPolymorphie. 15. Java Objektorientierung II
432 Polymorphie 15. Java Objektorientierung II Objektorientierung: Verschiedene Aspekte 433 Daten Typhierarchie Objekte Code Vererbung Unter- und Oberklassen Methoden überschreiben Unterklassen zuweisen
MehrIch liebe Java && Ich liebe C# Rolf Borst
Ich liebe Java && Ich liebe C# Rolf Borst Java oder C#? Einführung public class Einfuehrung { private int gesamtzahl = 0; /* Ermittelt die Anzahl der geraden und durch drei teilbaren Zahlen */ public String
MehrShort Introduction to C# C# (C SHARP) Microsofts Antwort auf Java
Short Introduction to C# C# (C SHARP) Microsofts Antwort auf Java Short Introduction to C# C# (C SHARP) Microsofts Antwort auf Java Standardisierung durch die ECMA und ISO Short Introduction to C# C# (C
MehrPolymorphie. 15. Java Objektorientierung II
446 Polymorphie 15. Java Objektorientierung II Objektorientierung: Verschiedene Aspekte 447 Daten Typhierarchie Objekte Code Vererbung Unter- und Oberklassen Methoden überschreiben Unterklassen zuweisen
Mehr12) Generische Datenstrukturen
12) Generische Datenstrukturen Prof. Dr. rer. nat. habil. Uwe Aßmann Lehrstuhl Softwaretechnologie Fakultät für Informatik TU Dresden Version 09-0.2, 24.11.08 Softwaretechnologie, Prof. Uwe Aßmann 1 mpfohlene
MehrScala Was gibt s Neues?
Java Forum Stuttgart 1 Prof. Dr. Oliver Braun o.braun@fh-sm.de Fakultät Informatik Fachhochschule Schmalkalden 01. Juli 2010 Java Forum Stuttgart 2 Überblick ursprünglich nur Collections neu schreiben
MehrFunktionales Programmieren mit objektorientierten Sprachen
Funktionales Programmieren mit objektorientierten Sprachen Dr. Dieter Hofbauer d.hofbauer@ba-nordhessen.de Hochschule Darmstadt, WS 2008/09 p.1/21 Function Objects In funktionalen Sprachen (Haskell, ML,...
MehrMusterlösung Stand: 5. Februar 2009
Fakultät IV Elektrotechnik/Informatik Probeklausur Einführung in die Informatik I Hinweis: Diese Probeklausur ist eine kleine Aufgabensammlung, die etwa dem Schwierigkeitsgrad der Teilleistung TL 2 (Programmiertest)
Mehr