meillo@0: % @file meillo@0: % @brief Referat DesignPattern `Observer' meillo@0: % @author markus schnalke meillo@0: % @since 2007-05-30 meillo@0: meillo@0: meillo@0: \documentclass{beamer} meillo@0: meillo@0: meillo@0: \usepackage[T1]{fontenc} meillo@0: \usepackage[latin1]{inputenc} meillo@0: \usepackage{ngerman} meillo@0: \usepackage{graphicx} meillo@0: \usepackage[automark]{scrpage2} meillo@0: \input{Style01} meillo@0: meillo@0: meillo@0: meillo@0: \begin{document} meillo@0: meillo@0: meillo@0: \title{Design Pattern ``Observer''} meillo@0: \date{\today} meillo@0: meillo@0: \author{Markus Schnalke} meillo@0: meillo@0: %\titlegraphic{\includegraphics[width=3cm]{Pics/Maka-Logo.png}} meillo@0: meillo@0: \frame{ meillo@0: \titlepage meillo@0: } meillo@0: meillo@0: meillo@0: meillo@0: meillo@0: meillo@0: \section[Outline]{} meillo@0: \frame{ meillo@0: Dauer der Präsentation: etwa 10 Minuten meillo@0: \vspace{2ex} meillo@0: meillo@0: \tableofcontents meillo@0: } meillo@0: meillo@0: meillo@0: meillo@0: meillo@3: \section{Vorgehensweise} meillo@0: meillo@3: \frame{ \frametitle{Von der anderen Seite} meillo@0: meillo@3: \begin{block}{Gründe} meillo@3: Design Pattern sind so etwas wie ``Best Practices'' (also bewährte meillo@3: Vorgehensweisen), oft \textbf{nach Vorbildern in der Wirklichkeit} meillo@3: \end{block} meillo@3: \pause meillo@3: \begin{block}{Meine Vorgehensweise} meillo@3: Ich will nun anhand eines Beispiels aus dem täglichen Leben zeigen, dass meillo@3: das Design Pattern ``Observer'' ein absolut natürliches Vorgehen ist, das meillo@3: bei ähnlichen Situationen in Programmen deshalb ebenso verwendet werden meillo@3: sollte. meillo@3: \end{block} meillo@3: meillo@3: % todo: Mehr und ausführlicher; Verweis auf nach dem Vortrag meillo@3: meillo@3: } meillo@3: meillo@3: meillo@3: \section{Erarbeitung des Observers} meillo@3: meillo@3: \frame{ \frametitle{Ein Beispiel} meillo@3: meillo@3: \begin{block}{Die Situation} meillo@0: \begin{itemize} meillo@3: \item Personen die verkaufen möchten meillo@3: \item Personen die kaufen möchten meillo@3: \item Sie wollen/sollen sich nicht kennen meillo@3: \item Möglichst effektives Vorgehen meillo@0: \end{itemize} meillo@0: \end{block} meillo@0: \pause meillo@3: \begin{block}{Vorschläge?} meillo@0: \begin{itemize} meillo@0: \item meillo@0: \item meillo@0: \end{itemize} meillo@0: \end{block} meillo@0: meillo@0: } meillo@0: meillo@0: meillo@5: \subsection{Ansatz} meillo@3: \frame{ \frametitle{Ansatz} meillo@0: meillo@3: \begin{block}{Mögliche Vorgehen} meillo@3: \begin{itemize} meillo@3: \item Personen direkt ansprechen meillo@3: \item Laut in die Menge rufen meillo@3: \item Den Freunden erzählen, die es dann weitererzählen meillo@3: \end{itemize} meillo@3: \end{block} meillo@0: meillo@3: \pause meillo@0: meillo@3: \begin{block}{Probleme} meillo@3: \begin{itemize} meillo@3: \item Man weiß nicht wer Interesse hat meillo@3: \item nicht mal wieviele meillo@3: \item Manche Interessenten sind vielleicht nur zu bestimmten Zeiten da meillo@3: \item ... oder sie sind taub meillo@3: \end{itemize} meillo@3: \end{block} meillo@0: meillo@0: } meillo@0: meillo@0: meillo@4: meillo@4: \subsection{Erarbeitung einer Lösung} meillo@4: meillo@3: \frame{ \frametitle{Eine (gute) Lösung: Pinnwand} meillo@0: meillo@3: \begin{block}{Funktionsweise} meillo@3: \begin{itemize} meillo@3: \item Man kann Zettel anpinnen meillo@3: \item Hingehen und nach neuen Zetteln schauen meillo@3: \item Zettel lesen meillo@3: \item Zettel abnehmen meillo@3: \item Jeder der ein paar Fähigkeiten hat kann es meillo@3: \end{itemize} meillo@3: \end{block} meillo@0: meillo@3: \pause meillo@3: meillo@3: \begin{block}{Probleme} meillo@3: \begin{itemize} meillo@3: \item Man muss hingehen, nur um festzustellen, dass nichts Neues dabei ist meillo@3: \item Man kann wichtige Zettel verpassen meillo@3: \item Zettel sollten nicht weggenommen werden können meillo@3: \end{itemize} meillo@3: \end{block} meillo@3: meillo@0: } meillo@0: meillo@0: meillo@0: meillo@3: meillo@4: \frame{ \frametitle{Verbesserung: Pinnwand-Sekretärin} meillo@3: meillo@3: \begin{block}{Lösung} meillo@3: \begin{itemize} meillo@3: \item Durch Studiengebühren wird eine Sekretärin für die Pinnwand angestellt meillo@3: \item Pinnwand und Sekretärin sind fortan eine Einheit meillo@3: \item Man kann bei ihr einen Zettel in Auftrag geben (auch telefonisch) meillo@3: \item (Sie schreibt mit lesbarer Schrift) meillo@3: \item Sie verhindert, dass Zettel abgenommen werden meillo@3: \end{itemize} meillo@3: \end{block} meillo@3: meillo@3: \pause meillo@3: meillo@3: \begin{block}{Bestehendes Problem} meillo@3: \begin{itemize} meillo@3: \item Man läuft immer noch oft unnötig zur Pinnwand meillo@3: \end{itemize} meillo@3: \end{block} meillo@3: meillo@3: } meillo@3: meillo@3: meillo@4: \frame{ \frametitle{2. Verbesserung: Pinnup-Sekretärin mit Benachrichtigung} meillo@3: meillo@3: \begin{block}{Lösung} meillo@3: \begin{itemize} meillo@3: \item Durch Studiengebühren wird eine längere Arbeitszeit der Sekretärin finanziert meillo@3: \item Man kann sich bei der Sekretärin nun als ``Interessierter'' registrieren meillo@3: \item Die Sekretärin trägt die Telefonnummer in eine Liste ein meillo@3: \item Fortan ruft sie alle Personen der Liste an, wenn sie einen neuen Zettel anpinnt meillo@3: \end{itemize} meillo@3: \end{block} meillo@3: meillo@3: } meillo@3: meillo@3: meillo@4: \subsection{Zusammenfassung} meillo@4: meillo@3: % Zusammenfassung des Beispiels: Was haben wir, ist alles abgedeckt meillo@3: % Frage: Sind die Zuhörer zufrieden? Ist die Lösung gut? meillo@4: \frame{ \frametitle{Zusammenfassung des Beispiels} meillo@4: meillo@4: \begin{block}{Pinnwand + Sekretärin + Benachrichtigung} meillo@4: \begin{itemize} meillo@4: \item Man kann neue Zettel anpinnen lassen meillo@4: \item Man kann sich als Interessierter anmelden (und auch abmelden) meillo@4: \item Interessierte werden bei Änderungen der Pinnwand benachrichtigt meillo@4: \item Sie können dann zur Pinnwand gehen und sie sich anschauen meillo@4: \end{itemize} meillo@4: \end{block} meillo@4: meillo@4: \pause meillo@4: meillo@4: \begin{block}{Eure Meinung?} meillo@4: \begin{itemize} meillo@4: \item Ist diese Struktur zufriedenstellend? meillo@4: \item Erfüllt sie alle Anforderungen? meillo@4: \item Was fehlt? meillo@4: \end{itemize} meillo@4: \end{block} meillo@4: meillo@4: } meillo@4: meillo@4: meillo@4: meillo@4: meillo@3: meillo@3: meillo@3: \section{Nun zum Pattern} meillo@3: meillo@4: meillo@4: \frame{ \frametitle{Überleitung} meillo@4: meillo@4: \begin{block}{Neue Namen} meillo@4: \begin{itemize} meillo@4: \item Pinnwand-Sekretärin-Einheit -> ``Subject'' meillo@4: \item Die Zettel auf der Pinnwand -> ``subjectState'' meillo@4: \item Interessenten -> ``Observers'' meillo@4: \end{itemize} meillo@4: \end{block} meillo@4: meillo@4: \pause meillo@4: meillo@4: \begin{block}{Schnittstellen} meillo@4: Die Fähigkeiten die Pinnwand/Sekretärin und Interessenten haben müssen um in diesem Schema korrekt zu funktionieren sind ihre ``Interfaces''. meillo@4: \end{block} meillo@4: meillo@4: } meillo@4: meillo@4: meillo@3: \frame { \frametitle{UML-Diagramm des Observers} meillo@4: \centerline{ \includegraphics[width=20em]{pics/observer.png} } meillo@3: } meillo@3: meillo@3: meillo@3: % Daten aus der Beschreibung des Observers von GoF meillo@3: % in welche Gruppen wird er eingeordnet meillo@4: \frame{ \frametitle{Beschreibung des Observers} meillo@4: meillo@4: \begin{block}{Klassifizierung} meillo@4: Verhaltensmuster, objektbasierend meillo@4: \end{block} meillo@4: meillo@4: \begin{block}{Auch bekannt als} meillo@4: Publish-Subscribe, Dependents meillo@4: \end{block} meillo@4: meillo@4: \begin{block}{Zweck} meillo@4: Abhängigkeiten zwischen Objekten zu erstellen, sodass sich abhängige Objekte ändern, wenn sich das Objekt selbst ändert. meillo@4: % todo: besser formulieren meillo@4: \end{block} meillo@4: meillo@4: \begin{block}{Kurzbeschreibung} meillo@4: Schnittstellen anlegen, um Abhängigkeiten zwischen Objekten registriert meillo@4: werden können, und um die abhängigen Objekte über Zustandsänderungen zu meillo@4: informieren. meillo@4: % todo: Formulierung überdenken meillo@4: \end{block} meillo@4: meillo@4: } meillo@3: meillo@3: meillo@5: \subsection{Beispiele} meillo@3: % Einsatzgebiete (MVC) und RL (Mailingslisten, Ebay-Suchabo) meillo@3: % nicht aber (Blog + RSS) meillo@5: \frame{ \frametitle{Der Observer in der Praxis} meillo@4: meillo@5: \begin{block}{Beispiele} meillo@5: \begin{itemize} meillo@5: \item Observer ist sehr verbreitet meillo@5: \item v.a. MVC (Model = Subject; View = Observer) meillo@5: \item Mailinglisten meillo@5: \item Ebay Such-Abo meillo@5: \end{itemize} meillo@4: \end{block} meillo@4: meillo@4: \pause meillo@4: meillo@5: \begin{block}{Aber} meillo@5: \begin{itemize} meillo@5: nicht Blog mit RSS-Feed! meillo@5: \end{itemize} meillo@4: \end{block} meillo@4: meillo@4: } meillo@3: meillo@3: meillo@5: \subsection{Erweiterungen} meillo@3: % Erweiterungen, verbleibende Probleme, Kompromisse beim Design meillo@4: \frame{ \frametitle{} meillo@4: meillo@4: \begin{block}{} meillo@4: \end{block} meillo@4: meillo@4: } meillo@3: meillo@3: meillo@3: meillo@3: \section{Zusammenfassung} meillo@5: \frame{ %\frametitle{Zusammenfassend} meillo@3: \begin{block}{Zusammenfassung} meillo@0: \begin{itemize} meillo@0: \item meillo@0: \item meillo@0: \item meillo@0: \end{itemize} meillo@0: \end{block} meillo@0: meillo@0: \pause meillo@0: meillo@3: \begin{block}{Fazit} meillo@3: \begin{itemize} meillo@3: \item meillo@3: \item meillo@3: \item meillo@3: \end{itemize} meillo@0: \end{block} meillo@0: } meillo@0: meillo@0: meillo@0: \section{Fragen} meillo@0: \frame{ \frametitle{Fragen?} meillo@0: \vspace{5ex} meillo@0: \centerline{\huge ?} meillo@0: } meillo@0: meillo@0: meillo@5: % Erklaerung des Vorgehens meillo@5: % Frage: war es erfolgreich? meillo@5: \frame{ \frametitle{} meillo@5: meillo@5: \begin{block}{} meillo@5: \end{block} meillo@5: meillo@5: } meillo@5: meillo@5: meillo@0: \frame{ \frametitle{Abschließend} meillo@0: \begin{block}{Verwendete Software} meillo@0: \begin{itemize} meillo@0: \item Debian GNU/Linux meillo@0: \item \LaTeX-Beamer und \texttt{pdflatex} meillo@0: \item Vim meillo@3: \item qiv und ImageMagick meillo@5: \item Mercurial meillo@0: \end{itemize} meillo@0: \end{block} meillo@0: meillo@0: \begin{block}{} meillo@0: \vspace{3ex} meillo@0: \centerline{\textbf{Danke für eure Aufmerksamkeit}} meillo@0: \end{block} meillo@0: } meillo@0: meillo@0: meillo@3: % Code (Beispiel-Implementierung) meillo@3: meillo@3: meillo@0: meillo@0: \end{document} meillo@3: meillo@3: meillo@3: meillo@3: meillo@3: meillo@3: meillo@3: %\subsubsection{Fehlteilmanagement} meillo@3: %\frame{ \frametitle{Fehlteilmanagement} meillo@3: % %\includegraphics[width=10cm]{Pics/cc.png} meillo@3: %} meillo@3: meillo@3: % \vspace{2ex}