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