view detailed-observer.tex @ 23:e206112b4afe

added zusammenfassung to einfuehrung
author meillo@marmaro.de
date Tue, 26 Jun 2007 22:04:19 +0200
parents a7ab86cddfad
children ddd8378a539e
line wrap: on
line source

% @file
% @brief   Referat DesignPattern `Observer'
% @author  markus schnalke <meillo@marmaro.de>
% @since   2007-05-30


\documentclass{beamer}


  \usepackage[T1]{fontenc}
  \usepackage[latin1]{inputenc}
  \usepackage{ngerman}
  \usepackage{graphicx}
  \usepackage[automark]{scrpage2}
  \input{Style01}



\begin{document}


\title{Design Pattern ``Observer''}
\date{\today}

\author{Markus Schnalke}

%\titlegraphic{\includegraphics[width=3cm]{Pics/Maka-Logo.png}}

\frame{
  \titlepage
}





\section[Outline]{}
\frame{
  \tableofcontents
}




\section{Vorgehensweise}

\frame{ \frametitle{Von der anderen Seite}

  \begin{block}{Gründe}
    Design Pattern sind so etwas wie ``Best Practices'' (also bewährte
    Vorgehensweisen), oft \textbf{nach Vorbildern in der Wirklichkeit}
  \end{block}
  \pause
  \begin{block}{Meine Vorgehensweise}
    Ich will nun anhand eines Beispiels aus dem täglichen Leben zeigen, dass
    das Design Pattern ``Observer'' ein absolut natürliches Vorgehen ist, das
    bei ähnlichen Situationen in Programmen deshalb ebenso verwendet werden
    sollte.
  \end{block}

  % todo: Mehr und ausführlicher; Verweis auf nach dem Vortrag

}


\section{Erarbeitung des Observers}

\frame{ \frametitle{Ein Beispiel}

  \begin{block}{Die Situation}
    \begin{itemize}
      \item Personen die verkaufen möchten
      \item Personen die kaufen möchten
      \item Sie wollen/sollen sich nicht kennen
      \item Möglichst effektives Vorgehen
    \end{itemize}
  \end{block}
  \pause
  \begin{block}{Vorschläge?}
    \begin{itemize}
      \item 
      \item 
    \end{itemize}
  \end{block}

}


\subsection{Ansatz}
\frame{ \frametitle{Ansatz}

  \begin{block}{Mögliche Vorgehen}
  \begin{itemize}
    \item Personen direkt ansprechen
    \item Laut in die Menge rufen
    \item Den Freunden erzählen, die es dann weitererzählen
  \end{itemize}
  \end{block}

  \pause

  \begin{block}{Probleme}
    \begin{itemize}
      \item Man weiß nicht wer Interesse hat
      \item nicht mal wieviele
      \item Manche Interessenten sind vielleicht nur zu bestimmten Zeiten da
      \item ... oder sie sind taub
    \end{itemize}
  \end{block}

}



\subsection{Erarbeitung einer Lösung}

\frame{ \frametitle{Eine (gute) Lösung: Pinnwand}

  \begin{block}{Funktionsweise}
  \begin{itemize}
    \item Man kann Zettel anpinnen
    \item Hingehen und nach neuen Zetteln schauen
    \item Zettel lesen
    \item Zettel abnehmen
    \item Jeder der ein paar Fähigkeiten hat kann es
  \end{itemize}
  \end{block}

  \pause

  \begin{block}{Probleme}
    \begin{itemize}
      \item Man muss hingehen, nur um festzustellen, dass nichts Neues dabei ist
      \item Man kann wichtige Zettel verpassen
      \item Zettel sollten nicht weggenommen werden können
    \end{itemize}
  \end{block}

}




\frame{ \frametitle{Verbesserung: Pinnwand-Sekretärin}

  \begin{block}{Lösung}
  \begin{itemize}
    \item Durch Studiengebühren wird eine Sekretärin für die Pinnwand angestellt
    \item Pinnwand und Sekretärin sind fortan eine Einheit
    \item Man kann bei ihr einen Zettel in Auftrag geben (auch telefonisch)
    \item (Sie schreibt mit lesbarer Schrift)
    \item Sie verhindert, dass Zettel abgenommen werden
  \end{itemize}
  \end{block}

  \pause

  \begin{block}{Bestehendes Problem}
    \begin{itemize}
      \item Man läuft immer noch oft unnötig zur Pinnwand
    \end{itemize}
  \end{block}

}


\frame{ \frametitle{2. Verbesserung: Pinnup-Sekretärin mit Benachrichtigung}

  \begin{block}{Lösung}
  \begin{itemize}
    \item Durch Studiengebühren wird eine längere Arbeitszeit der Sekretärin finanziert
    \item Man kann sich bei der Sekretärin nun als ``Interessierter'' registrieren
    \item Die Sekretärin trägt die Telefonnummer in eine Liste ein
    \item Fortan ruft sie alle Personen der Liste an, wenn sie einen neuen Zettel anpinnt
  \end{itemize}
  \end{block}

}


\subsection{Zusammenfassung}

% Zusammenfassung des Beispiels: Was haben wir, ist alles abgedeckt
% Frage: Sind die Zuhörer zufrieden? Ist die Lösung gut?
\frame{ \frametitle{Zusammenfassung des Beispiels}

  \begin{block}{Pinnwand + Sekretärin + Benachrichtigung}
    \begin{itemize}
      \item Man kann neue Zettel anpinnen lassen
      \item Man kann sich als Interessierter anmelden (und auch abmelden)
      \item Interessierte werden bei Änderungen der Pinnwand benachrichtigt
      \item Sie können dann zur Pinnwand gehen und sie sich anschauen
    \end{itemize}
  \end{block}

  \pause

  \begin{block}{Eure Meinung?}
    \begin{itemize}
      \item Ist diese Struktur zufriedenstellend?
      \item Erfüllt sie alle Anforderungen?
      \item Was fehlt?
    \end{itemize}
  \end{block}

}






\section{Nun zum Pattern}


\frame{ \frametitle{Überleitung}

  \begin{block}{Neue Namen}
    \begin{itemize}
      \item Pinnwand-Sekretärin-Einheit -> ``Subject''
      \item Die Zettel auf der Pinnwand -> ``subjectState''
      \item Interessenten -> ``Observers''
    \end{itemize}
  \end{block}

  \pause

  \begin{block}{Schnittstellen}
    Die Fähigkeiten die Pinnwand/Sekretärin und Interessenten haben müssen um in diesem Schema korrekt zu funktionieren sind ihre ``Interfaces''.
  \end{block}

}


\frame { \frametitle{UML-Diagramm des Observers}
  \centerline{ \includegraphics[width=20em]{pics/observer_big.png} }
}


% Daten aus der Beschreibung des Observers von GoF
% in welche Gruppen wird er eingeordnet
\frame{ \frametitle{Beschreibung des Observers}

  \begin{block}{Klassifizierung}
    Verhaltensmuster, objektbasierend
  \end{block}

  \begin{block}{Auch bekannt als}
    Publish-Subscribe, Dependents
  \end{block}

  \begin{block}{Zweck}
    Abhängigkeiten zwischen Objekten zu erstellen, sodass sich abhängige Objekte ändern, wenn sich das Objekt selbst ändert.
    % todo: besser formulieren
  \end{block}

  \begin{block}{Kurzbeschreibung}
    Schnittstellen anlegen, um Abhängigkeiten zwischen Objekten registriert
    werden können, und um die abhängigen Objekte über Zustandsänderungen zu
    informieren.
    % todo: Formulierung überdenken
  \end{block}

}


\subsection{Beispiele}
% Einsatzgebiete (MVC) und RL (Mailingslisten, Ebay-Suchabo)
% nicht aber (Blog + RSS)
\frame{ \frametitle{Der Observer in der Praxis}

  \begin{block}{Beispiele}
    \begin{itemize}
      \item Observer ist sehr verbreitet
      \item v.a. MVC (Model = Subject; View = Observer)
      \item Mailinglisten
      \item Ebay Such-Abo
    \end{itemize}
  \end{block}

  \pause

  \begin{block}{Aber}
    \begin{itemize}
      \item nicht Blog mit RSS-Feed!
    \end{itemize}
  \end{block}

}


\subsection{Erweiterungen}
% Erweiterungen, verbleibende Probleme, Kompromisse beim Design
\frame{ \frametitle{}

  \begin{block}{}
  \end{block}

}



\section{Zusammenfassung}
\frame{ %\frametitle{Zusammenfassend}
  \begin{block}{Zusammenfassung}
  \begin{itemize}
    \item 
    \item 
    \item 
  \end{itemize}
  \end{block}

  \pause

  \begin{block}{Fazit}
    \begin{itemize}
      \item 
      \item 
      \item 
    \end{itemize}
  \end{block}
}


\section{Fragen}
\frame{ \frametitle{Fragen?}
  \vspace{5ex}
  \centerline{\huge ?}
}


% Erklaerung des Vorgehens
% Frage: war es erfolgreich?
\frame{ \frametitle{}

  \begin{block}{}
  \end{block}

}


\frame{ \frametitle{Abschließend}
  \begin{block}{Verwendete Software}
  \begin{itemize}
    \item Debian GNU/Linux
    \item \LaTeX-Beamer und \texttt{pdflatex}
    \item Vim
    \item qiv und ImageMagick
    \item Mercurial
  \end{itemize}
  \end{block}

  \begin{block}{}
    \vspace{3ex}
    \centerline{\textbf{Danke für eure Aufmerksamkeit}}
  \end{block}
}


% Code (Beispiel-Implementierung)






%\input{main2.tex}


\end{document}






%\subsubsection{Fehlteilmanagement}
%\frame{ \frametitle{Fehlteilmanagement}
%  %\includegraphics[width=10cm]{Pics/cc.png}
%}

% \vspace{2ex}