Skip to content

Latest commit

 

History

History
111 lines (95 loc) · 4.16 KB

README.md

File metadata and controls

111 lines (95 loc) · 4.16 KB

Next

  • Karte für Präsentation
  • 123rf.com
    • 37811632 (vector)
  • Scala-Code anschauen, hinterfragen und anpassen

TBD

  • Java code gleich schreiben, wie scala
  • Scala ausprobieren
    • abstract override
    • mehrfach vererbung mit zweimal von abstract class erben im trait
    • Trait ruft nicht super, sondern eine andere Method direkt auf (z.B. depo/withdraw mit dem Betrag positiv)

Sample code

To run performance benchmarks:

  1. start sbt
  2. enter jmh:run -bm avgt -i 3 -tu ms -wi 3 -f1 -t1

Refer to https://github.com/ktoso/sbt-jmh

Videos

https://vimeo.com/20290504

https://www.youtube.com/watch?v=v-adlWyS4Ww

https://www.youtube.com/watch?v=PgTBrzR8TJg https://www.youtube.com/watch?v=WNrqFdRVvjQ https://www.infoq.com/articles/benchmarking-jvm https://www.infoq.com/articles/java-8-vs-scala https://www.infoq.com/articles/scala-java-myths-facts​ https://www.youtube.com/watch?v=_qRYOayG9SM https://www.infoq.com/interviews/richardson-functional-java https://www.infoq.com/presentations/How-We-Mostly-Moved-from-Java-to-Scala https://www.youtube.com/watch?v=8vxTowBXJSg https://www.youtube.com/watch?v=PKc5IwHG68k https://www.youtube.com/watch?v=6vdYuy5-Yqc https://www.youtube.com/watch?v=mo7-VHYYSWQ

Articles

https://www.infoq.com/articles/java-8-vs-scala http://www.codeproject.com/Articles/893211/Differences-Between-Scala-and-Java-Part http://www.codeproject.com/Articles/897624/Differences-Between-Scala-and-Java-Part https://dzone.com/articles/scala-vs-java-another-view?utm_source=Top%205&utm_medium=email&utm_campaign=top5%202016-10-07 http://alvinalexander.com/scala/how-scala-killed-oop-strategy-design-pattern

To Discuss

  • package objects

  • def

  • name:Type

  • Unit

  • public

  • Wo sind die ;

  • Wo ist der .

  • Wo ist return (Return optional aber möglich)

  • Wo ist der Type (Type interference)

  • symbolische methoden

  • (? vs if)

  • Side effects (immutability)

    • Skalierung mit Anzahl cores vs shared mutable state
    • (Mutable hashCode Problem)
  • Named parameter

    • !! Entfernen eines Feldes bei einer Klasse: DRY
    • default parameter
  • Umsetzung von Design Patterns (z,B: Singleton, Command, …)

    • Builder Pattern Java vs Scala
    • Command Pattern
    • Filter auf Felder einer Sub-Klasse?
  • Tupels -> Bank.posts in Java/Scala

  • Map ->

    • Symbolic names in scala like -> :
    • == wird übersetzt als equals, eq ist wie == in Java
    • PersonenGruppe + Person mit implizierter Konvertierung
  • Implicit conversion

    • Kann zu magic führen
  • {} kann fast überall anstelle von was anderem stehen z.B. Bei getOrElese bei Option

  • Monads mit Option und Try (mehere withdraws)

  • Pattern Matching

  • Traits

    • (Self types)
  • Immutability!!! Z.B: wenn wir einen Schreibfehler im Namen korrigieren

    • GC -> Performance, Memory,...
  • import

    • relativ

    • renaming -> Namens-Clash mit Java-Klassen

    • multiple

    • places im code

  • String interpolation -> toString

  • Besser lesbar, da es viel dichter ist. Keine/wenig Zeremonie im Vergleich zu Java

    • For comprehension vs map/flatMap (readability)
    • Balance zwischen Lesbarkeit und Sprach-Möglichkeiten und Kompaktheit finden
  • Fuer Scala muss man nicht alles schon verstanden haben, der Einstieg ist sehr einfach.

    • Scala bring viele neue (einfache) Möglichkeiten
    • Scala ist Java ohne die mühsamen Sachen (. ; redundanzen in Namen)
    • Scala ist eine Offenbarung nach 20 Jahren Java Unterdrückung. Scala entfesselt meine Fähigkeiten
  • Scala ist auf den ersten Blick sehr Nahe beo Java: Runtime JVM, IDE (IntelliJ, Eclipse), Libraries

  • symblische methoden namen

  • post-, in-fix notation

  • null is böse! if (value != null & value ....) =>> es gibt option, die das if unnötig macht. Das gleiche mit leeren Collection. Manchmal hat null auch eine implizite Semantik

  • Nesting von Funktionen und anderen Sachen ist wichtig!!

  • we are to busy um etwas neues zu lernen

Ueber Bank buchen, da das Account sich verändert.

Fragen stellen wie: wievielte Kunden haben ein Guthaben von mehr als 1000 (wobei ein Kunde mehrere Kontos haben kann).

Essenz: Java ist mutable der Default, bei Scala Immutable. Collection Framework von Java geht von Mutable aus und es ist eher mühsam mit immutable zu arbeiten (ein Element mit einem Fluent Interface hinzufügen).