Scala.tex 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. %!TEX root = Programmierparadigmen.tex
  2. \chapter{Scala}
  3. \index{Scala|(}
  4. Scala ist eine objektorientierte und funktionale Programmiersprache, die auf der JVM aufbaut und in Java Bytecode kompiliert wird. Scala bedeutet \underline{sca}lable
  5. \underline{la}nguage.
  6. Mit sog. \enquote{actors} bietet Scala eine Unterstützung für die Entwicklung
  7. prallel ausführender Programme.
  8. Weitere Materialien sind unter \url{http://www.scala-lang.org/} und
  9. \url{http://www.simplyscala.com/} zu finden.
  10. \section{Erste Schritte}
  11. Scala kann auf Debian-basierten Systemen durch das Paket \texttt{scala} installiert
  12. werden. Für andere Systeme stehen auf \url{http://www.scala-lang.org/download/}
  13. verschiedene Binärdateien bereit.
  14. \subsection{Hello World}
  15. \subsubsection{Interaktiv}
  16. \inputminted[numbersep=5pt, tabsize=4]{bash}{scripts/scala/scala-test.scala}
  17. Es kann mit \texttt{./scala-test.scala Scala funktioniert} ausgeführt werden.
  18. \subsubsection{Kompiliert}
  19. \inputminted[linenos, numbersep=5pt, tabsize=4, frame=lines, label=hello-world.scala]{scala}{scripts/scala/hello-world.scala}
  20. Dieses Beispiel kann mit \texttt{scalac hello-world.scala} kompiliert und mit
  21. \texttt{scala HelloWorld} ausgeführt werden.
  22. \section{Vergleich mit Java}
  23. Scala und Java haben einige Gemeinsamkeiten, wie den Java Bytecode, aber auch
  24. einige Unterschiede.
  25. \noindent\parbox[t]{2.4in}{\raggedright%
  26. \textbf{\textit{Gemeinsamkeiten}}
  27. \begin{itemize}[topsep=0pt,itemsep=-2pt,leftmargin=13pt]
  28. \item Java Bytecode
  29. \item Keine Mehrfachvererbung
  30. \item Statische Typisierung
  31. \item Scopes
  32. \end{itemize}
  33. }%
  34. \parbox[t]{2.4in}{\raggedright%
  35. \textbf{\textit{Unterschiede}}
  36. \begin{itemize}[topsep=0pt,itemsep=-2pt,leftmargin=13pt]
  37. \item Java hat Interfaces, Scala hat traits.
  38. \item Java hat primitive Typen, Scala ausschließlich Objekte.
  39. \item Scala benötigt kein \texttt{;} am Ende von Anweisungen.
  40. \item Scala ist kompakter.
  41. \item Java hat \texttt{static}, Scala hat \texttt{object} (Singleton)
  42. \end{itemize}
  43. }
  44. Weitere Informationen hat Graham Lea unter \url{http://tinyurl.com/scala-hello-world} zur Verfügung gestellt.
  45. \section{Syntax}
  46. In Scala gibt es sog. \textit{values}, die durch das Schlüsselwort \texttt{val}\xindex{val}
  47. angezeigt werden. Diese sind Konstanten. Die Syntax ist der UML-Syntax ähnlich.
  48. \inputminted[numbersep=5pt, tabsize=4]{scala}{scripts/scala/val-syntax.scala}
  49. Variablen werden durch das Schlüsselwort \texttt{var}\xindex{var} angezeigt:
  50. \inputminted[numbersep=5pt, tabsize=4]{scala}{scripts/scala/var-syntax.scala}
  51. Methoden werden mit dem Schlüsselwort \texttt{def}\xindex{def} erzeugt:
  52. \inputminted[numbersep=5pt, tabsize=4]{scala}{scripts/scala/method-syntax.scala}
  53. Klassen werden wie folgt erstellt:
  54. \inputminted[numbersep=5pt, tabsize=4]{scala}{scripts/scala/simple-class-example.scala}
  55. und so instanziiert:
  56. \inputminted[numbersep=5pt, tabsize=4]{scala}{scripts/scala/simple-class-instanciation.scala}
  57. Listen können erstellt und durchgegangen werden:
  58. \inputminted[numbersep=5pt, tabsize=4]{scala}{scripts/scala/extended-for.scala}
  59. \section{Companion Object}\xindex{Companion Object}
  60. Ein Companion Object ist ein Objekt mit dem Namen einer Klasse oder eines Traits.
  61. Im Gegensatz zu anderen Objekten / Traits hat das Companion Object zugriff auf
  62. die Klasse.
  63. \section{actor}
  64. \begin{definition}[Aktor]\xindex{Aktor}\index{actor|see{Aktor}}
  65. Ein \textit{Aktor} ist ein Prozess, der Nebenläufig zu anderen Aktoren
  66. läuft. Er kommuniziert mit anderen Aktoren, indem er Nachrichten austauscht.
  67. \end{definition}
  68. Das folgende Wetter-Beispiel zeigt, wie man Aktoren benutzen kann.
  69. \section{Beispiele}
  70. \subsection{Wetter}
  71. Das folgende Script sendet parallel Anfragen über verschiedene ZIP-Codes an
  72. die Yahoo-Server, parst das XML und extrahiert die Stadt sowie die Temperatur:
  73. \inputminted[linenos, numbersep=5pt, tabsize=4, frame=lines, label=weather.scala]{scala}{scripts/scala/weather.scala}
  74. \section{Weitere Informationen}
  75. \begin{itemize}
  76. \item \url{http://docs.scala-lang.org/style/naming-conventions.html}
  77. \end{itemize}
  78. \index{Scala|)}