Agile Softwareentwicklung mit C#
|
|
|
- Franka Baumgartner
- vor 9 Jahren
- Abrufe
Transkript
1 Gary McLean Hall Agile Softwareentwicklung mit C# Best Practices und Patterns für flexiblen und adaptiven C#-Code
2 Gary McLean Hall lebt mit seiner Frau, seiner Tochter und ihrem Hund in Manchester, England. Er ist ein erfahrener Microsoft.NET Framework-Entwickler, der sich auf Patterns und Best Practices spezialisiert hat. In vielen Jahren als Softwareentwickler hat er in zahlreichen agilen Teams gearbeitet, die sich stark auf das Ziel konzentriert haben, Code zu erstellen, der äußerst anpassungsfähig ist. Er hat für Unternehmen wie Eidos, Xerox, Nephila Capital Ltd. und The LateRooms Group gearbeitet. Außerdem hat er mehrere Jahre lang ein Softwareconsultingunternehmen geleitet und drei Jahre lang auf Bermuda gelebt und gearbeitet. In allen Rollen hat er es immer geschafft, eine beeindruckende Balance zwischen pünktlicher Auslieferung eines Softwareprodukts und der Qualität seines Quellcodes zu finden. Zu diesem Buch sowie zu vielen weiteren dpunkt.büchern können Sie auch das entsprechende E-Book im PDF-Format herunterladen. Werden Sie dazu einfach Mitglied bei dpunkt.plus + :
3 Gary McLean Hall Agile Softwareentwicklung mit C# Best Practices und Patterns für flexiblen und adaptiven C#-Code
4 Gary McLean Hall Übersetzung: Detlef Johannis, Kempten Lektorat: Thomas Braun-Wiesholler, München Copy-Editing: Dorothee Klein, Siegen Herstellung: Frank Heidt Satz: Gerhard Alfes, mediaservice, Siegen, Umschlaggestaltung: Helmut Kraus, Druck und Bindung: M.P. Mediaprint Informationsdienste, Paderborn Bibliografische Information der Deutschen Nationalbibliothek Die Deutsche Nationalbibliothek verzeichnet diese Publikation in der Deutschen Nationalbibliografie; detaillierte bibliografische Daten sind im Internet über abrufbar. ISBN: Buch PDF epub Translation Copyright für die deutschsprachige Ausgabe 2015 dpunkt.verlag GmbH Wieblinger Weg Heidelberg Copyright der amerikanischen Originalausgabe Gary McLean Hall, 2014 Title of American original: Adaptive Code via C# Published by Microsoft Press ISBN: Die vorliegende Publikation ist urheberrechtlich geschützt. Alle Rechte vorbehalten. Die Verwendung der Texte und Abbildungen, auch auszugsweise, ist ohne die schriftliche Zustimmung des Verlags urheberrechtswidrig und daher strafbar. Dies gilt insbesondere für die Vervielfältigung, Übersetzung oder die Verwendung in elektronischen Systemen. Es wird darauf hingewiesen, dass die im Buch verwendeten Soft- und Hardware-Bezeichnungen sowie Markennamen und Produktbezeichnungen der jeweiligen Firmen im Allgemeinen warenzeichen-, marken- oder patentrechtlichem Schutz unterliegen. Alle Angaben und Programme in diesem Buch wurden mit größter Sorgfalt kontrolliert. Weder Autor noch Verlag können jedoch für Schäden haftbar gemacht werden, die in Zusammenhang mit der Verwendung dieses Buches stehen
5 Für Amelia Rose Gary McLean Hall
6
7 Inhaltsübersicht Einführung 1 TEIL I Eine agile Grundlage Kapitel 1 Einführung in Scrum 13 Kapitel 2 Abhängigkeiten und Schichten 57 Kapitel 3 Schnittstellen und Entwurfs-Patterns 111 Kapitel 4 Unit-Tests und Refaktorierung 147 TEIL II Schreiben von SOLID-Code Kapitel 5 Das Single-Responsibility-Prinzip 195 Kapitel 6 Das Open/Closed-Prinzip 237 Kapitel 7 Das Liskovsche Substitutionsprinzip 247 Kapitel 8 Interface-Segregation 283 Kapitel 9 Dependency-Injection 317 TEIL III Entwickeln von adaptivem Code in der Praxis Kapitel 10 Beispiel für die Entwicklung von adaptivem Code: Einführung 365 Kapitel 11 Beispiel für die Entwicklung von adaptivem Code: Sprint Kapitel 12 Beispiel für die Entwicklung von adaptivem Code: Sprint TEIL IV Anhang Anhang A Adaptive Tools 427 Anhang B GitHub-Codebeispiele online Stichwortverzeichnis 435 vii
8
9 Inhaltsverzeichnis Einführung 1 Wer sollte dieses Buch lesen Aufbau dieses Buchs Konventionen in diesem Buch Systemvoraussetzungen Downloads: Codebeispiele Danksagungen Errata und Support Kostenlose E-Books von Microsoft Press TEIL I Eine agile Grundlage Kapitel 1 Einführung in Scrum 13 Scrum und Wasserfall Rollen und Verantwortungsbereiche Product Owner Scrum Master Entwicklungsteam Schweine und Hühner Artefakte Das Scrum-Board Diagramme und Kennzahlen Backlogs Der Sprint Releaseplanung Sprintplanung Daily Scrum Sprintvorführung Sprint-Retrospektive Scrum-Kalender Probleme beim Einsatz von Scrum und Agile Nicht adaptiver Code Zusammenfassung ix
10 Kapitel 2 Abhängigkeiten und Schichten 57 Die Definition von Abhängigkeit Ein simples Beispiel Modellieren von Abhängigkeiten in einem gerichteten Graphen Verwalten von Abhängigkeiten Implementierungen und Schnittstellen Der verdächtige Geruch von new Alternativen zur Objekterstellung Das Anti-Pattern Entourage Das Stairway-Pattern Auflösen von Abhängigkeiten Abhängigkeitsverwaltung mit NuGet Schichten Wichtige Patterns Grenzüberschreitende Angelegenheiten Asymmetrische Schichteinteilung Zusammenfassung Kapitel 3 Schnittstellen und Entwurfs-Patterns 111 Was ist eine Schnittstelle? Syntax Explizite Implementierung Polymorphie Adaptive Entwurfs-Patterns Das Null-Object-Pattern Das Adapter-Pattern Das Strategy-Pattern Mehr Vielseitigkeit Duck-Typing Mixins Flüssige Schnittstellen Zusammenfassung Kapitel 4 Unit-Tests und Refaktorierung 147 Unit-Tests Arrange, Act, Assert Testorientierte Entwicklung Komplexere Tests x Inhaltsverzeichnis
11 Refaktorieren Vorhandenen Code ändern Ein neuer Kontotyp Zusammenfassung TEIL II Schreiben von SOLID-Code Kapitel 5 Das Single-Responsibility-Prinzip 195 Das Problem Refaktorieren, um die Übersichtlichkeit zu verbessern Refaktorieren, um Abstraktion zu erreichen SRP und das Decorator-Pattern Das Composite-Pattern Predicate-Decorator Branching-Decorator Lazy-Decorator Logging-Decorator Profiling-Decorator Asynchronous-Decorator Decorator für Eigenschaften und Ereignisse Verwenden des Strategy-Patterns statt switch Zusammenfassung Kapitel 6 Das Open/Closed-Prinzip 237 Einführung in das Open/Closed-Prinzip Die Meyer-Definition Die Martin-Definition Fehlerkorrekturen Lose Kopplung Erweiterungspunkte Code ohne Erweiterungspunkte Virtuelle Methoden Abstrakte Methoden Schnittstellenvererbung Vererbung in den Entwurf einarbeiten Geschützte Variation Prognostizierte Variation Eine stabile Schnittstelle Gerade genug Anpassungsfähigkeit Zusammenfassung Inhaltsverzeichnis xi
12 Kapitel 7 Das Liskovsche Substitutionsprinzip 247 Einführung in das Liskovsche Substitutionsprinzip Formale Definition LSP-Regeln Verträge Vorbedingungen Nachbedingungen Dateninvarianten Liskovsche Vertragsregeln Codeverträge Kovarianz und Kontravarianz Definitionen Liskovsche Typsystemregeln Zusammenfassung Kapitel 8 Interface-Segregation 283 Ein Beispiel für Interface-Segregation Eine einfache CRUD-Schnittstelle Caching Dekorieren mehrerer Schnittstellen Verwenden von Schnittstellen in Clients Mehrere Implementierungen, mehrere Instanzen Einzelne Implementierung, einzelne Instanz Das Interface-Soup-Anti-Pattern Zerlegen von Schnittstellen Anforderungen des Clients Anforderungen der Architektur Schnittstellen mit einer einzigen Methode Zusammenfassung Kapitel 9 Dependency-Injection 317 Bescheidene Anfänge Die Aufgabenlistenanwendung Erstellen des Objektgraphen Inversion of Control xii Inhaltsverzeichnis
13 Jenseits der simplen Injection Das Service-Locator-Anti-Pattern Das Illegitimate-Injection-Anti-Pattern Die Composition-Root Konvention vor Konfiguration Zusammenfassung TEIL III Kapitel 10 Kapitel 11 Entwickeln von adaptivem Code in der Praxis Beispiel für die Entwicklung von adaptivem Code: Einführung 365 Trey Research Das Team Das Produkt Anfängliches Backlog User Stories in Prosabeschreibungen finden Abschätzen der Story-Punkte Zusammenfassung Beispiel für die Entwicklung von adaptivem Code: Sprint Planung »Ich will Räume anlegen, um Unterhaltungen thematisch einzugrenzen.« Der Controller Das Raum-Repository »Ich will eine Liste der Räume ansehen, die Unterhaltungen repräsentieren.«392»ich will die Nachrichten ansehen, die an einen Raum geschickt wurden.«. 397»Ich will reine Textnachrichten an andere Raummitglieder schicken.« Sprintvorführung Erste Vorführung von Proseware Sprint-Retrospektive Was lief gut? Was lief schlecht? Was sollte sich ändern? Was sollte beibehalten werden? Überraschungen? Zusammenfassung Inhaltsverzeichnis xiii
14 Kapitel 12 Beispiel für die Entwicklung von adaptivem Code: Sprint Planung »Ich will Markdown senden, der richtig formatiert ist.« »Ich will Nachrichteninhalte so filtern, dass sie nicht anstößig sind.« »Ich will Hunderte von Benutzern gleichzeitig bedienen.« Sprintvorführung Sprint-Retrospektive Was lief gut? Was lief schlecht? Was sollte sich ändern? Was sollte beibehalten werden? Überraschungen? Zusammenfassung TEIL IV Anhang Anhang A Adaptive Tools 427 Quellcodeverwaltung mit Git Kontinuierliche Integration Anhang B GitHub-Codebeispiele online Stichwortverzeichnis 435 xiv Inhaltsverzeichnis
15 Einführung Der Begriff adaptiver Code aus dem Untertitel dieses Buchs liefert eine gute Beschreibung für das Ergebnis, das Sie erhalten, wenn Sie die Prinzipien des Buchs anwenden: die Fähigkeit von Code, sich an alle neuen Anforderungen oder unvorhergesehenen Szenarien anpassen zu lassen, ohne dass er dafür in weiten Teilen umgearbeitet werden muss. Dieses Buch hat das Ziel, viele der aktuellen Best Practices aus dem Bereich der C#-Programmierung mit dem Microsoft.NET Framework in einem Band zusammenzufassen. Ein Teil des Inhalts wird zwar auch in anderen Büchern behandelt, aber diese Bücher konzentrieren sich entweder stark auf die Theorie oder sind nicht spezifisch auf die.net-entwicklung zugeschnitten. Programmierung kann ein langsamer Prozess sein. Wenn Ihr Code adaptiv ist, sind Sie in der Lage, Änderungen schneller, einfacher und mit weniger Fehlern vorzunehmen, als wenn Sie mit einer Codebasis arbeiten, die Änderungen behindert. Wie jeder Entwickler weiß, ändern sich Anforderungen. Auf welche Weise mit diesen Änderungen umgegangen wird, macht den Unterschied zwischen erfolgreichen Softwareprojekten und denen aus, die aufgrund eines völlig außer Kontrolle geratenen Umfangs steckenbleiben. Entwickler können auf unterschiedliche Arten auf Änderungen der Anforderungen reagieren, wobei zwei gegensätzliche Standpunkte die Extreme des Spektrums bilden. Erstens können Entwickler einen inflexiblen Standpunkt einnehmen. Bei diesem Ansatz ist das Projekt angefangen beim Entwicklungsprozess bis hinunter zum Klassenentwurf so inflexibel, als wäre es vor 50 Jahren mithilfe von Lochkarten implementiert worden. Wasserfall-Methodologien sind bekannte Vertreter dieser Zunft, der es darum geht sicherzustellen, dass sich Software nicht nach Belieben verändern darf. Ihr Beharren darauf, dass die Phasen von Analyse, Entwurf, Implementierung und Testen voneinander isoliert bleiben und nur in einer Richtung nacheinander abgearbeitet werden, macht es schwierig oder zumindest teuer für den Kunden, irgendwelche Anforderungen zu verändern, nachdem die Implementierung erst einmal begonnen hat. Der Code braucht daher gar nicht so beschaffen zu sein, dass er leicht zu ändern ist: Der Prozess verbietet praktisch Änderungen. Der zweite Ansatz, agile Methodologie, besteht nicht etwa darin, lediglich eine Alternative zu solch inflexiblen Methodologien zu finden. Er will eine Reaktion auf sie sein. Agile 1
16 Prozesse haben sich das Ziel gesetzt, Änderungen als unerlässlichen Teil des Vertrags zwischen Kunde und Entwickler willkommen zu heißen. Wenn Kunden etwas an dem Produkt, für das sie bezahlen, verändern wollen, sollten der Zeitaufwand und die finanziellen Kosten den Umfang der Änderung widerspiegeln, aber nicht abhängig von der Phase sein, in der sich der Prozess momentan befindet. Im Unterschied zu anderen technischen Disziplinen arbeitet Software-Engineering mit einem äußerst elastischen Werkzeug: Quellcode. Die Steine und Mörtel, aus denen ein Haus entsteht, werden fest miteinander verbunden, während der Bau fortschreitet. Der Aufwand, um den Entwurf eines Hauses zu verändern, hängt natürlich davon ab, in welcher Phase sich der Bauprozess befindet. Hat der Bau noch gar nicht begonnen (wenn also bisher nur Pläne vorliegen), ist eine Änderung relativ billig. Sind die Fenster eingebaut, die elektrischen Leitungen verlegt und die Wasserrohre angeschlossen, wäre es unglaublich teuer, das obere Badezimmer nach unten neben die Küche zu verlegen. Bei Code sollte es nicht so aufwendig sein, Features zu verschieben und die Navigation einer Benutzeroberfläche umzugestalten. Leider ist das aber nicht immer der Fall. Allein der Zeitaufwand verhindert oft solche Änderungen. Daran ist meiner Ansicht nach vor allem eine fehlende Anpassungsfähigkeit des Codes schuld. Dieses Buch demonstriert den zweiten Ansatz und erklärt anhand von Praxisbeispielen die Vorgehensweise beim Implementieren adaptiven Codes. Wer sollte dieses Buch lesen Dieses Buch soll die Lücke zwischen Theorie und Praxis schließen. Der Leser, für den das Buch geschrieben wurde, ist ein erfahrener Programmierer, der eher praktische Beispiele für Entwurfs-Patterns, SOLID-Prinzipien, Unit-Tests, Refaktorierung und andere Techniken sucht. Fortgeschrittene Programmierer, die Wissenslücken stopfen wollen oder Zweifel und Fragen darüber haben, wie wichtige Best Practices der Branche zusammenpassen, profitieren am meisten von diesem Buch, besonders weil der Alltag beim Programmieren nur selten den oft simplen Beispielen oder gar der Theorie entspricht. Weite Teile von SOLID sind bekannt, aber die Feinheiten des Open/Closed-Prinzips (siehe Kapitel 6) und des Liskovschen Substitutionsprinzips (Kapitel 7) werden nicht vollständig verstanden. Selbst erfahrenen Programmierern ist manchmal nicht völlig klar, welche Vorteile die Dependency-Injection bietet (Kapitel 9). Genauso wird oft übersehen, welche Flexibilität und somit Anpassungsfähigkeit Schnittstellen dem Code verleihen (Kapitel 3). Dieses Buch kann auch unerfahrenen Entwicklern helfen, weil sie hier von Grund auf lernen, welche Aspekte bekannter Patterns und Best Practices nützlich sind und welche langfristig eher schädlich. Der Code, den ich von Stellenbewerbern oft zu sehen bekomme, hat viele Gemeinsamkeiten. Der allgemeine Entwurf zeigt, dass der Bewerber bei vielen Fähigkeiten fast soweit ist, aber noch ein wenig Unterstützung braucht, um ein deutlich besserer Programmierer zu werden. Besonders das Entourage-Anti-Pattern (Kapitel 2) und das Service-Locator-Anti-Pattern (Kapitel 9) sind in den präsentierten Codebeispielen all- 2 Einführung
17 gegenwärtig. Praktische Alternativen und Begründungen, warum sie sinnvoller sind, werden in diesem Buch beschrieben. Erforderliche Vorkenntnisse Im Idealfall haben Sie bereits einige praktische Erfahrung im Programmieren mit einer Sprache, deren Syntax C# ähnelt, zum Beispiel Java oder C++. Sie sollten außerdem eine solide Grundlage in Konzepten der prozeduralen Programmierung haben, beispielsweise bedingte Verzweigungen, Schleifen und Ausdrücke. Und Sie sollten etwas Erfahrung in der objektorientierten Programmierung mit Klassen haben und von Schnittstellen wenigstens schon gehört haben. Dieses Buch eignet sich wahrscheinlich nicht für Sie, wenn Dieses Buch eignet sich wahrscheinlich nicht für Sie, wenn Sie gerade erst anfangen, das Programmieren zu lernen. Dieses Buch behandelt fortgeschrittene Themen, die solide Kenntnisse grundlegender Programmierkonzepte voraussetzen. Aufbau dieses Buchs Dieses Buch besteht aus drei Teilen, die jeweils aufeinander aufbauen. Trotzdem müssen Sie das Buch nicht von Anfang bis Ende durchlesen. Jedes Kapitel ist in sich abgeschlossen und behandelt ein bestimmtes Thema. Wo es sinnvoll ist, finden Sie Querverweise auf andere Kapitel. Teil I: Eine agile Grundlage Dieser Teil schafft die Grundlage zum Erstellen von Software, die adaptiv ist. Er bietet einen Überblick über den agilen Prozess Scrum, für den Code benötigt wird, der sich einfach an Änderungen anpassen lässt. Die übrigen Kapitel in diesem Teil konzentrieren sich auf Details zu Schnittstellen, Entwurfs-Patterns, Refaktorierung und Unit-Tests. Kapitel 1: Einführung in Scrum Dieses Kapitel eröffnet das Buch mit einer Einführung in Scrum, eine agile Projektverwaltungsmethodologie. Das Kapitel bietet einen detaillierten Überblick über die Artefakte, Rollen, Kennzahlen und Phasen eines Scrum-Projekts. Es zeigt außerdem, wie Entwickler sich selbst und ihren Code organisieren sollten, wenn sie in einer agilen Umgebung tätig sind. Kapitel 2: Abhängigkeiten und Schichten Dieses Kapitel beschäftigt sich mit Abhängigkeiten und Schichtarchitektur. Code kann nur adaptiv sein, wenn die Struktur der Lösung dies zulässt. Es werden die unterschied- Aufbau dieses Buchs 3
18 lichen Arten von Abhängigkeiten beschrieben: Eigenabhängigkeiten, Fremdabhängigkeiten und Frameworkabhängigkeiten. Das Kapitel beschreibt, wie Sie Abhängigkeiten verwalten und organisieren, von Anti-Patterns (die Sie vermeiden sollten) bis zu Patterns (die Sie nutzen sollten). Außerdem steigt es mit fortgeschrittenen Themen wie aspektorientierter Programmierung und asymmetrischer Schichtung tiefer in wichtige Programmiertechniken ein. Kapitel 3: Schnittstellen und Entwurfs-Patterns Schnittstellen sind in der modernen.net-entwicklung allgegenwärtig. Allerdings werden sie oft falsch verwendet, missverstanden und missbraucht. Dieses Kapitel zeigt einige bekannte und nützliche Entwurfs-Patterns und beschreibt, wie vielseitig eine Schnittstelle sein kann. Während das Kapitel den Leser durch die Schritte zur simplen Extrahierung einer Schnittstelle führt, zeigt es, wie Schnittstellen auf viele unterschiedliche Arten genutzt werden können, um ein Problem zu lösen. Mixins, Duck-Typing und flüssige Schnittstellen unterstreichen weiter die Vielseitigkeit dieser zentralen Waffe im Arsenal des Programmierers. Kapitel 4: Unit-Tests und Refaktorierung Zwei Techniken, die heutzutage jeder Programmierer beherrschen muss, sind Unit-Tests und Refaktorierung. Die beiden hängen eng miteinander zusammen und ihre Kombination produziert adaptiven Code. Ohne das Sicherheitsnetz von Unit-Tests ist die Refaktorierung fehlerträchtig. Und ohne Refaktorierung wird Code unhandlich, inflexibel und schwierig zu verstehen. Dieses Kapitel arbeitet ein Beispiel für Unit-Tests von bescheidenen Anfängen bis zu fortgeschrittenen, aber praktischen Patterns durch und stellt flüssige Assert-Verkettung, testorientierte Entwicklung und Mocking vor. Im Bereich der Refaktorierung demonstriert das Kapitel anhand praxisorientierter Beispiele, wie Sie die Lesbarkeit und Wartungsfreundlichkeit von Quellcode verbessern. Teil II: Schreiben von SOLID-Code Dieser Teil baut auf den Grundlagen auf, die in Teil I geschaffen wurden. Jedes Kapitel widmet sich einem Prinzip von SOLID. Dabei erklären diese Kapitel nicht einfach die trockene Theorie, sondern demonstrieren anhand von Praxisbeispielen die Umsetzung der Prinzipien. Indem jedes Beispiel in einen realen Kontext gesetzt wird, stellen die Kapitel in diesem Teil des Buchs den Nutzen von SOLID eindrucksvoll unter Beweis. Kapitel 5: Das Single-Responsibility-Prinzip Dieses Kapitel zeigt, wie Sie das Single-Responsibility-Prinzip in der Praxis mithilfe von Decorator- und Adapter-Pattern umsetzen. Die Anwendung des Prinzips führt dazu, dass mehr Klassen entstehen, diese Klassen aber kleiner werden. Das Kapitel zeigt, dass sich diese kleineren Klassen im Unterschied zu monolithischen Klassen, die einen großen Funktionsumfang enthalten, auf eine bestimmte Aufgabe beschränken und sich darauf konzentrieren, lediglich einen kleinen Teilaspekt eines größeren Problems zu lösen. In der Kombination mehrerer dieser Klassen zeigt sich dann die beeindruckende Leistungsfähigkeit der Einzelteile und des Gesamtsystems. 4 Einführung
19 Kapitel 6: Das Open/Closed-Prinzip Das Open/Closed-Prinzip klingt einfach, kann aber erhebliche Auswirkungen auf den Code haben. Es soll sicherstellen, dass Code, der den SOLID-Prinzipien folgt, nur erweitert, aber niemals bearbeitet wird. Dieses Kapitel stellt außerdem das Konzept der prognostizierten Variation in Bezug auf das Open/Closed-Prinzip vor und beschreibt, wie es Entwicklern hilft, mithilfe von Erweiterungspunkten die Anpassungsfähigkeit zu erhöhen. Kapitel 7: Das Liskovsche Substitutionsprinzip Dieses Kapitel zeigt, welche Vorteile es bringt, das Liskovsche Substitutionsprinzip auf Code anzuwenden. Besonders wird dabei auf die Tatsache eingegangen, dass diese Regeln helfen, das Open/Closed-Prinzip einzuhalten und versehentliche Beschädigungen aufgrund von Veränderungen zu verhindern. Es wird gezeigt, wie Verträge mit Vorbedingungen, Nachbedingungen und Dateninvarianten durch den Einsatz von Codeverträgen definiert und überprüft werden. Außerdem beschreibt das Kapitel wichtige Regeln zur Ableitung von Typen, zum Beispiel Kovarianz, Kontravarianz und Invarianz, und demonstriert die Auswirkungen, falls diese Regeln gebrochen werden. Kapitel 8: Interface-Segregation Nicht nur Klassen sollten kleiner sein, als sie oft sind, dieses Kapitel zeigt, dass auch Schnittstellen oft zu groß sind. Interface-Segregation ist eine simple Technik, die oft übersehen wird. Dieses Kapitel zeigt, welche Vorteile es hat, Schnittstellen möglichst klein zu halten und mit diesen kleinen Schnittstellen zu arbeiten. Außerdem nennt es unterschiedliche Gründe, die für das Auftrennen von Schnittstellen sprechen, zum Beispiel Anforderungen des Clients oder der Architektur. Kapitel 9: Dependency-Injection Dieses Kapitel beschäftigt sich mit dem Klebstoff, der die übrigen Techniken dieses Buchs zusammenhält. Ohne Dependency-Injection wäre vieles gar nicht möglich, sie ist wirklich derart wichtig. Dieses Kapitel enthält eine Einführung in Dependency-Injection und vergleicht die unterschiedlichen Methoden für ihre Implementierung. Das Kapitel behandelt die Verwaltung von Objektlebensdauern, die Arbeit mit Inversion-of-Control-Containern, das Vermeiden häufiger Anti-Patterns im Bereich von Diensten und das Analysieren von Composition-Roots und Resolution-Roots. Teil III: Entwickeln von adaptivem Code in der Praxis Dieser Teil demonstriert anhand einer Beispielanwendung, wie die im Buch beschriebenen Techniken kombiniert werden. Diese Kapitel enthalten eine Menge Code, er wird aber ausführlich erklärt. Weil dieses Buch sich mit der Arbeit in einer agilen Umgebung beschäftigt, orientieren sich die Kapitel an Scrum-Sprints und die durchgeführten Arbeiten sind das Ergebnis von Backlog-Einträgen und Änderungswünschen des Kunden. Aufbau dieses Buchs 5
20 Kapitel 10: Beispiel für die Entwicklung von adaptivem Code: Einführung Dieses erste Kapitel beschreibt die Anwendung, die entwickelt werden soll: eine Online- Chat-Anwendung, die mit ASP.NET-MVC 5 entwickelt wird. Ein knapper Entwurf zeigt die geplante Architektur, außerdem werden die Features im Backlog erläutert. Kapitel 11: Beispiel für die Entwicklung von adaptivem Code: Sprint 1 Unter Anwendung eines testorientierten Entwicklungsansatzes werden die ersten Features der Anwendung entwickelt, darunter das Anzeigen und Erstellen von Chaträumen und Nachrichten. Kapitel 12: Beispiel für die Entwicklung von adaptivem Code: Sprint 2 Natürlich hat der Kunde einige Änderungen an den Anforderungen der Anwendung gemacht und das Team ist in der Lage, diese Änderungswünsche zu erfüllen, weil es adaptiven Code geschrieben hat. Anhänge In den Anhängen finden Sie einige Referenzinformationen, konkret eine Anleitung für die Arbeit mit der Quellcodeverwaltung Git und eine Erklärung, wie der Code für dieses Buch auf GitHub organisiert ist. Anhang A: Adaptive Tools Dies ist eine knappe Einführung in die Quellcodeverwaltung Git, die Sie zumindest in die Lage versetzen sollte, den Code von GitHub herunterzuladen und ihn in Microsoft Visual Studio 2013 zu kompilieren. Dies soll kein ausführliches Git-Handbuch sein für diesen Zweck gibt es bereits hervorragende Informationsquellen, zum Beispiel das offizielle Git-Tutorial unter Mit einer Suchmaschine finden Sie bei Bedarf viele andere Quellen. Außerdem stellt dieser Anhang kurz einige andere Entwicklertools vor, zum Beispiel kontinuierliche Integration. Anhang B (nur online und in englischer Sprache): GitHub-Codebeispiele Indem ich den Code für dieses Buch auf GitHub bereitstelle, kann ich Änderungen an einer zentralen Stelle vornehmen. Das Repository ist schreibgeschützt, aber die Anhänge A und B verraten Ihnen, wie Sie den Code für ein Listing finden, herunterladen, kompilieren, ausführen und lokal verändern können. Wenn Sie denken, Sie haben einen Fehler gefunden, oder eine Änderung vorschlagen wollen, können Sie ein Pull- Request für das Repository schicken; ich sehe es mir gerne an. Anhang B finden Sie unter microsoftpressstore.com auf der Seite zu diesem Buch. Konventionen in diesem Buch In diesem Buch werden besondere Textelemente durch verschiedene Konventionen hervorgehoben. Wenn Sie bereits andere Bücher von Microsoft Press gelesen haben, sind Sie vermutlich damit vertraut. Falls nicht, können Sie sich in diesem Abschnitt darüber informieren. 6 Einführung
21 Codelistings Dieses Buch enthält zahlreiche Codelistings, deren Bedeutung kurz in einer Listingunterschrift erklärt wird (Listing 0 1). public void MyService : IService { } List. 0 1 Dies ist ein Codelisting. Sie finden etliche davon im Buch. Wenn Ihre Aufmerksamkeit auf einen bestimmten Teil des Codes gelenkt werden soll, weil zum Beispiel Änderungen gegenüber dem vorherigen Beispiel vorgenommen wurden, sind die entsprechenden Abschnitte fett hervorgehoben. Hinweise und Textkästen Hinweiskästen werden für kurze Anmerkungen und Hinweise verwendet, während Textkästen umfangreichere Themen behandeln. Hier einige Beispiele: HINWEIS Dies ist ein Hinweiskasten. Er enthält kurze Informationsbröckchen, die sich auf den Inhalt beziehen, aber besonders wichtig sind. Dies ist ein Textkasten Dieser Textkasten ist zwar relativ kurz, aber meist enthalten sie längere Beiträge zu Themen, die leicht vom Hauptthema abschweifen. Systemvoraussetzungen Sie brauchen die folgende Hardware und Software, um die Codebeispiele in diesem Buch zu verwenden: Windows XP Service Pack 3 (außer Starter Edition), Windows Vista Service Pack 2 (außer Starter Edition), Windows 7, Windows Server 2003 Service Pack 2, Windows Server 2003 R2, Windows Server 2008 Service Pack 2 oder Windows Server 2008 R2 Visual Studio 2013, beliebige Edition (falls Sie Express Edition-Produkte verwenden, sind unter Umständen mehrere Downloads erforderlich) Systemvoraussetzungen 7
22 Microsoft SQL Server 2008 Express Edition oder höher (2008 oder R2 Release), mit SQL Server Management Studio 2008 Express oder höher (enthalten in Visual Studio; für Express Editions ist ein separater Download erforderlich) Computer mit einem Prozessor mit mindestens 1,6 GHz (2 GHz empfohlen) 1 GByte (bei einer 32-Bit-Version) oder 2 GByte (bei einer 64-Bit-Version) RAM (weitere 512 MByte, falls Sie einen virtuellen Computer verwenden oder SQL Server Express Editions einsetzen, mehr bei leistungsfähigeren SQL Server-Editionen) 3,5 GByte freier Festplattenplatz Festplattenlaufwerk mit U/min DirectX 9-fähige Grafikkarte an einem Monitor mit mindestens 1024 x 768 Pixel Auflösung DVD-ROM-Laufwerk (falls Sie Visual Studio von DVD installieren) Internetverbindung zum Herunterladen von Software und Codebeispielen Abhängig von Ihrer Windows-Konfiguration benötigen Sie unter Umständen Administratorrechte, um Visual Studio 2013 und SQL Server 2008-Produkte zu installieren oder zu konfigurieren. Downloads: Codebeispiele Soweit möglich, habe ich sichergestellt, dass die Codelistings aus einem größeren Beispiel stammen, das entweder als eigenständige Anwendung oder als Unit-Test ausgeführt werden kann. Viele der einfacheren Unit-Tests habe ich mit MSTest geschrieben, daher wird kein externer Test-Runner dafür benötigt, aber für die komplexeren Unit-Tests habe ich auf NUnit zurückgegriffen. Den gesamten Code habe ich in Visual Studio 2013 Ultimate geschrieben. Einige Lösungen habe ich mithilfe der Preview-Version erstellt, aber sie wurden alle unter der fertigen Version kompiliert und getestet. Nach Möglichkeit habe ich keine Features verwendet, die in den Express Editions von Visual Studio 2013 nicht verfügbar sind, aber bei manchen Themen war das nicht möglich. Leser, die diesen Code ausführen wollen, müssen eine kommerzielle Version dafür installieren. Der Code selbst steht auf GitHub unter der folgenden Adresse zur Verfügung: Anhang A enthält eine Anleitung zur Benutzung von Git, während Anhang B (nur online) auflistet, in welchen Unterordnern des Git-Repositorys Sie die Listings aus den einzelnen Kapiteln finden. Wenn Sie eine Anmerkung zum Code haben, können Sie mir in meinem Blog eine Nachricht hinterlassen: 8 Einführung
23 Danksagungen Der Autorenname im Impressum vermittelt einen falschen Eindruck. Ich wäre nie in der Lage gewesen, dieses Buch ohne die folgenden Personen zu schreiben, die mir auf unterschiedliche Weise geholfen haben. Ich möchte danken: Victoria, meiner Frau, dafür, dass sie dieses Buch möglich gemacht hat. Das ist keine leere Floskel, sondern die reine Wahrheit. Amelia, meiner Tochter, dafür, dass sie in jeder Hinsicht perfekt ist. Pam, meiner Mutter, dafür, dass sie korrekturgelesen und mich mit wundervoll übertriebenem Lob angespornt hat. Les, meinem Vater, für all seine harte Arbeit. Darryn, meinem Bruder, für seine unermüdliche Hilfe und Unterstützung. Kathy Krause bei Online Training Solutions, für ihre hervorragende Arbeit, die dieses Buch lesbar gemacht hat. Devon Musgrave, für seine anscheinend grenzenlose Geduld. Errata und Support Wir haben uns sehr um die Richtigkeit der in diesem Buch enthaltenen Informationen bemüht. Fehler, die seit der Veröffentlichung bekannt geworden sind, werden auf der Microsoft Press-Website (in englischer Sprache) aufgelistet: Sollten Sie einen Fehler finden, der noch nicht aufgeführt ist, würden wir uns freuen, wenn Sie uns auf der gleichen Seite darüber informieren (in englischer Sprache). Mit Anmerkungen, Fragen oder Verbesserungsvorschlägen zu diesem Buch können Sie sich auch an den dpunkt.verlag wenden: Bitte beachten Sie, dass über unsere -Adresse kein Software-Support angeboten wird. Für Supportinformationen bezüglich der hier verwendeten Microsoft-Produkte besuchen Sie die Microsoft-Website Danksagungen 9
24 Kostenlose E-Books von Microsoft Press Von technischen Einführungen bis zu detaillierten Informationen über Spezialthemen decken die nur in Englisch verfügbaren kostenlosen E-Books von Microsoft Press eine große Themenbandbreite ab. Diese E-Books stehen in den Formaten PDF, EPUB und Mobi für Kindle zur Verfügung. Sie können sie herunterladen unter: Schauen Sie ab und zu vorbei, um sich zu informieren, was es Neues gibt! 10 Einführung
25 Teil I Eine agile Grundlage KAPITEL 1 Einführung in Scrum KAPITEL 2 Abhängigkeiten und Schichten KAPITEL 3 Schnittstellen und Entwurfs-Patterns KAPITEL 4 Unit-Tests und Refaktorierung Dieser Teil des Buchs führt in die Grundlagen von agilen Prinzipien und Verfahren ein. Das Schreiben von Code ist ein Grundpfeiler der Softwareentwicklung. Allerdings gibt es viele unterschiedliche Wege, lauffähigen Code zu erhalten. Selbst wenn Sie die Auswahl von Plattform, Sprache und Framework außen vor lassen, steht ein Entwickler sogar beim Implementieren simpelster Funktionen vor einer Vielzahl von Entscheidungen. Die Erstellung erfolgreicher Softwareprodukte ist schon immer das primäre Ziel der Softwareentwicklungsbranche. In den letzten Jahren haben sich Entwickler darauf verlegt, Patterns (Muster) und Verfahren zu implementieren, die reproduzierbar sind und sich positiv auf die Codequalität auswirken. Dies ist notwendig geworden, weil sich die Codequalität nicht mehr von der Qualität des fertigen Softwareprodukts trennen lässt. Im Lauf der Zeit wird minderwertiger Code die Qualität des Produkts herunterziehen, zumindest wird er die Auslieferung funktionierender Software verzögern. Um qualitativ hochwertige Software zu produzieren, müssen Entwickler sicherstellen, dass ihr Code gut wartbar, einfach zu lesen und vollständig getestet ist. Daneben hat sich als neue Anforderung herauskristallisiert, dass Code adaptiv, also anpassungsfähig sein sollte. Die Kapitel in diesem ersten Buchteil stellen moderne Softwareentwicklungsprozesse und -verfahren vor. Diese Prozesse und Verfahren werden zusammenfassend als agile Prozesse und Verfahren bezeichnet, womit betont werden soll, dass sich ihre Richtung schnell ändern kann. Agile Prozesse stellen Möglichkeiten bereit, wie ein Softwareentwicklungsteam schnelles Feedback erhalten und als Reaktion darauf seinen Fokus verschieben kann. Agile Verfahren bieten dagegen Wege, wie ein Softwareentwicklungsteam Code schreibt, der bei Bedarf eine neue Richtung einschlagen kann. 11
26
27 Kapitel 1 Einführung in Scrum Am Ende dieses Kapitels werden Sie in der Lage sein, die folgenden Aufgaben durchzuführen: Zuweisen von Rollen an die wichtigsten Stakeholder des Projekts Beschreiben der unterschiedlichen Dokumente und anderer Artefakte, die Scrum benötigt und produziert Messen des Fortschritts eines Scrum-Projekts im Lauf seiner Entwicklung Diagnostizieren von Problemen bei Scrum-Projekten und Vorschlagen von Gegenmitteln Abhalten von produktiven Scrum-Meetings, die allen Beteiligten nützen Begründen, warum Scrum und nicht andere agile oder rigide Methodologien eingesetzt werden Scrum ist eine Methodologie für die Projektverwaltung. Genauer gesagt handelt es sich um eine agile Methodologie. Das zentrale Konzept von Scrum beruht darauf, den Nutzen eines Softwareprodukts iterativ, also phasenweise, zu steigern. Der gesamte Scrum-Prozess wird mehrmals wiederholt (die Iterationen), bis das Softwareprodukt als vollständig beurteilt oder der Prozess abgebrochen wird. Diese Iterationen werden als Sprints bezeichnet. Sie münden in einer Software, die als fertiges Produkt freigegeben werden kann. Die gesamte Arbeit wird im sogenannten Produkt-Backlog (Produkt-Rückstand) in Prioritäten eingestuft, und bei Beginn jedes Sprints legt das Entwicklungsteam fest, welche Arbeiten es in der aktuellen Iteration erledigen wird, indem es diese Arbeiten im Sprint-Backlog festhält. Eine Arbeitseinheit innerhalb von Scrum wird als Story (Geschichte) bezeichnet. Das Produkt- Backlog ist eine nach Prioritäten sortierte Liste abzuarbeitender Stories, und jeder Sprint wird durch die Stories definiert, die während einer Iteration entwickelt werden. Abbildung 1 1 zeigt einen Überblick des Scrum-Prozesses. 13
28 Tägliche Arbeit Produkt-Backlog Sprint-Backlog Sprint Release Das Produkt-Backlog Jeder Sprint dauert enthält Features und zwischen einer und vier Stories, die implementiert Wochen. Jeden Tag werden sollen. bemüht sich das Team, die anstehenden Stories fertigzustellen. Stories, die in den Sprint aufgenommen wurden, werden in den Sprint-Backlog verschoben. Alle Stories werden in Reihenfolge ihrer Priorität implementiert. Nach jedem Sprint werden die neu implementierten Features in einer neuen Produktversion veröffentlicht. Abb. 1 1 Scrum ähnelt einer Fertigungsstraße für kleine Features eines Softwareprodukts Scrum umfasst verschiedene Dokumentationsartefakte, Rollen, die von Personen innerhalb und außerhalb des Entwicklungsteams übernommen werden, und Zeremonien, das heißt Meetings, an denen die relevanten Gruppen teilnehmen. Ein einziges Kapitel reicht nicht aus, um alle Vorteile von Scrum als Projektverwaltungsmethode aufzuzeigen, aber dieses Kapitel sollte Ihnen einen ausreichenden Überblick vermitteln, damit Sie sich bei Bedarf tiefer in bestimmte Teilbereiche einarbeiten können und die Bedeutung der üblichen Scrum- Verfahren durchblicken. Scrum ist agil Unter dem Begriff agil (engl. agile) wird eine Familie schlanker Softwareentwicklungsmethoden zusammengefasst, die es ermöglichen, auf geänderte Anforderungen der Kunden auch dann noch zu reagieren, wenn das Projekt bereits läuft. Agile Methoden sind die Antwort auf die Nachteile von Verfahren, die rigider strukturiert sind. Das Agile-Manifest macht diesen Gegensatz deutlich, Sie finden es unter Das Agile-Manifest wurde von 17 Softwareentwicklern unterzeichnet. Die Agile- Methode hat in den letzten Jahren so stark an Einfluss gewonnen, dass Erfahrung in einer agilen Umgebung zur unverzichtbaren Voraussetzung für einen Posten im Rahmen der Softwareentwicklung geworden ist. Scrum ist eine der am häufigsten genutzten Implementierungen eines agilen Prozesses. 14 Kapitel 1 Einführung in Scrum
29 Scrum und Wasserfall Ich habe die Erfahrung gemacht, dass in der Softwareentwicklung der agile Ansatz besser funktioniert als das Wasserfallmodell (engl. waterfall), daher empfehle ich grundsätzlich nur agile Prozesse. Das Problem bei der Wasserfallmethode ist ihre Inflexibilität. Abbildung 1 2 zeigt die Abläufe bei einem Wasserfallprojekt. Requirements/ Anforderungen Design/ Entwurf Implementation/ Implementierung Testing/ Überprüfung Deployment/ Bereitstellung Maintenance/ Wartung Abb. 1 2 Der Entwicklungsprozess bei der Wasserfallmethode Die Ergebnisse jeder Phase werden dabei zur Basis der nächsten Phase, und jede Phase wird vollständig abgeschlossen, bevor die nächste in Angriff genommen wird. Das setzt voraus, dass keine Fehler, Probleme, ungelösten Fragen oder Missverständnisse mehr auftauchen, nachdem eine Phase abgeschlossen ist. Die Pfeile zeigen nur in eine Richtung. Der Wasserfallprozess geht außerdem davon aus, dass nach Abschluss einer Phase keine Änderungen mehr vorgenommen werden. Diese Annahme lässt sich angesichts der eigenen Erfahrung und zahlreicher Untersuchungen einfach nicht aufrechterhalten. Änderungen gehören einfach zum Leben dazu, nicht nur bei der Softwareentwicklung. Wasserfallansätze behandeln Änderungen als etwas, das teuer und unerwünscht ist und daher unbedingt vermieden werden sollte. Wasserfallmethoden basieren auf dem Konzept, dass sich Änderungen vermeiden lassen, wenn man mehr Zeit auf die Ausarbeitung von Anforderungen und Entwurf verwendet. In diesem Denkkonzept tauchen Änderungen während der nachfolgenden Phasen schlicht nicht auf. Das ist natürlich lächerlich, weil sich immer Änderungen ergeben. Das Agile-Konzept begegnet diesem Problem, indem es einen fundamental anderen Ansatz verwendet, in dem Änderungen als etwas Positives betrachtet werden und jeder die Gelegenheit erhält, sich an alle auftretenden Änderungen anzupassen. Das Agile-Konzept Scrum und Wasserfall 15
30 und somit auch Scrum lassen zwar Änderungen auf Prozessebene zu, aber auf das Ziel künftiger Änderungen hin zu programmieren ist eine der schwierigsten und gleichzeitig wichtigsten Ziele moderner Softwareentwicklung. Dieses Buch will Ihnen zeigen, wie Sie Code erstellen, der so agil und adaptiv ist, dass er Änderungen übersteht. Wasserfallmethodologien sind außerdem dokumentzentriert, das heißt, sie produzieren große Mengen an Dokumentation, die nicht direkt das Softwareprodukt verbessert. Bei den Agile-Methoden wird dagegen die lauffähige Software als wichtigstes Dokument eines Softwareprodukts betrachtet. Das Verhalten der Software wird schließlich durch ihren Quellcode gesteuert, nicht durch die Dokumente, die begleitend zum Code verfasst wurden. Und weil die Dokumentation vom Quellcode getrennt ist, kann es leicht passieren, dass sie nicht mehr mit der Software übereinstimmt. Scrum definiert einige Kennzahlen, die Rückmeldungen zum Fortschritt eines Projekts und seinem Gesamtzustand liefern, aber das ist etwas anderes als eine erklärende Dokumentation über das Produkt. Agile-Methoden empfehlen im Allgemeinen, nur so viel Dokumentation zu produzieren, dass das Projekt nicht ins Unverantwortliche abkippt, aber sie schreiben eine solche Dokumentation meist nicht vor. Es gibt durchaus Code, der von ergänzender Dokumentation profitiert, sofern sie nicht einmal geschrieben und dann nie wieder gelesen wird. Aus diesem Grund sind lebendige, einfach zu nutzende Dokumente, wie beispielsweise Wikis, wichtige Werkzeuge in Scrum-Teams. Der Rest dieses Kapitels behandelt die wichtigsten Aspekte von Scrum genauer. Dabei konzentrieren wir uns nicht auf pures Scrum, sondern auf eine beliebte Variante. Das Ziel von Scrum als Prozess besteht nicht nur darin, das Softwareprodukt iterativ zu verbessern, sondern auch den Entwicklungsprozess. Das animiert die Teams, kleine Änderungen vorzunehmen und so dafür zu sorgen, dass sich der Prozess optimal für ihre konkrete Situation eignet. Nachdem die folgenden Abschnitte die Elemente von Scrum vorgestellt haben, analysiert der Rest des Kapitels ihre Schwächen. Dieses Kapitel bildet die Basis für das übrige Buch, das genauer ausführt, wie Sie Code so implementieren, dass er adaptiv ist und somit Änderungen ermöglicht, die im Scrum-Prozess als etwas Positives aufgefasst werden. Es wäre sinnlos, einen Prozess zu nutzen, in dem Sie den Anspruch erheben, Änderungen problemlos implementieren zu können, wenn in Wirklichkeit jegliche Änderung auf Codeebene unglaublich schwierig zu implementieren ist. Unterschiedliche Formen von Scrum Wenn ein Entwicklungsteam behauptet, eine Scrum-Methodologie umzusetzen, heißt das meist, dass sie eine Variante von Scrum einsetzen. Pures Scrum umfasst nur wenige Verfahren, die aus anderen Agile-Methoden übernommen wurden, zum Beispiel Extreme Programming (XP). Es gibt drei Unterkategorien von Scrum, die sich jeweils weiter von der reinen Lehre entfernen. 16 Kapitel 1 Einführung in Scrum
Agile Softwareentwicklung mit C#
Gary McLean Hall Agile Softwareentwicklung mit C# Best Practices und Patterns für flexiblen und adaptiven C#-Code Gary McLean Hall lebt mit seiner Frau, seiner Tochter und ihrem Hund in Manchester, England.
Inhaltsverzeichnis. Eine agile Grundlage. Einführung 1. Kapitel 1 Einführung in Scrum 13
Einführung 1 Wer sollte dieses Buch lesen......................................... 2 Aufbau dieses Buchs................................................ 3 Konventionen in diesem Buch........................................
Gradle. Ein kompakter Einstieg in modernes Build-Management. Joachim Baumann. Joachim Baumann, Gradle, dpunkt.verlag, ISBN
D3kjd3Di38lk323nnm Joachim Baumann Gradle Ein kompakter Einstieg in modernes Build-Management Joachim Baumann [email protected] Lektorat: René Schönfeldt Copy Editing: Sandra Gottmann, Münster-Nienberge
Sebastian Springer, Testgetriebene Entwicklung mit JavaScript, dpunkt.verlag, ISBN D3kjd3Di38lk323nnm
D3kjd3Di38lk323nnm Sebastian Springer ist Diplom-Informatiker (FH) und arbeitet als JavaScript-Entwickler bei der Mayflower GmbH in München. Neben seiner Tätigkeit als Consultant unterrichtet er als Dozent
Konfigurationsmanagement mit Subversion, Maven und Redmine
Gunther Popp Konfigurationsmanagement mit Subversion, Maven und Redmine Grundlagen für Softwarearchitekten und Entwickler 4., aktualisierte und erweiterte Auflage Gunther Popp [email protected] Lektorat:
Nicholas C. Zakas, JavaScript objektorientiert, dpunkt.verlag, ISBN D3kjd3Di38lk323nnm
D3kjd3Di38lk323nnm Zu diesem Buch sowie zu vielen weiteren dpunkt.büchern können Sie auch das entsprechende E-Book im PDF-Format herunterladen. Werden Sie dazu einfach Mitglied bei dpunkt.plus + : www.dpunkt.de/plus
Andreas Spillner / Ulrich Breymann, Lean Testing für C++-Programmierer, dpunkt.verlag, ISBN
Andreas Spillner ist Professor für Informatik an der Hochschule Bremen. Er war über 10 Jahre Sprecher der Fachgruppe TAV»Test, Analyse und Verifikation von Software«der Gesellschaft für Informatik e.v.
Dipl.-Inform. Arno Becker ist bei der visionera GmbH verantwortlich für den Bereich»Mobile Lösungen«. Nach langjähriger Erfahrung mit Java ME
Dipl.-Inform. Arno Becker ist bei der visionera GmbH verantwortlich für den Bereich»Mobile Lösungen«. Nach langjähriger Erfahrung mit Java ME beschäftigte er sich von Beginn an intensiv mit Android. Als
Die Kunst der JavaScript- Programmierung
D3kjd3Di38lk323nnm Marijn Haverbeke Die Kunst der JavaScript- Programmierung Eine moderne Einführung in die Sprache des Web Übersetzung: Volkmar Gronau, Flensburg Copy-Editing: Dr. Anja Stiller-Reimpell,
Dipl.-Inform. Arno Becker Dipl.-Inform. Marcus Pant
Dipl.-Inform. Arno Becker ist bei der visionera GmbH verantwortlich für den Bereich»Mobile Lösungen«. Nach langjähriger Erfahrung mit Java ME beschäftigte er sich von Beginn an intensiv mit Android. Als
Vision Was ist der Sinn und Zweck des Systems? Stakeholder Wem nützt es? Wer ist davon betroffen? Wer hat Einfluss darauf?
D3kjd3Di38lk323nnm Workshops im Requirements Engineering Warum? Vision Was ist der Sinn und Zweck des Systems? Stakeholder Wem nützt es? Wer ist davon betroffen? Wer hat Einfluss darauf? Rahmenbedingungen
Scrum in der Praxis. Erfahrungen, Problemfelder und Erfolgsfaktoren. Bearbeitet von Dipl.-Inform. Sven Röpstorff, Dipl.-Kaufm.
Scrum in der Praxis Erfahrungen, Problemfelder und Erfolgsfaktoren Bearbeitet von Dipl.-Inform. Sven Röpstorff, Dipl.-Kaufm. Robert Wiechmann 1. Auflage 2012. Buch. 348 S. Hardcover ISBN 978 3 89864 792
Abenteuer Softwarequalität
Kurt Schneider Abenteuer Softwarequalität Grundlagen und Verfahren für Qualitätssicherung und Qualitätsmanagement 2., überarbeitete und erweiterte Auflage Prof. Dr. Kurt Schneider [email protected]
Abenteuer Softwarequalität
Abenteuer Softwarequalität Grundlagen und Verfahren für Qualitätssicherung und Qualitätsmanagement Bearbeitet von Kurt Schneider erweitert, überarbeitet 2012. Taschenbuch. 264 S. Paperback ISBN 978 3 89864
Software entwickeln mit Verstand
D3kjd3Di38lk323nnm Jörg Dirbach Markus Flückiger Steffen Lentz Software entwickeln mit Verstand Was Sie über Wissensarbeit wissen müssen, um Projekte produktiver zu machen Jörg Dirbach [email protected]
ios-apps programmieren mit Swift
Christian Bleske ios-apps programmieren mit Swift Der leichte Einstieg in die Entwicklung für iphone, ipad und Co. inkl. Apple Watch und Apple TV 2., aktualisierte und erweiterte Auflage Christian Bleske
Über die Autoren. www.dpunkt.de/plus
Über die Autoren Joan Lambert beschäftigt sich seit 1986 umfassend mit Microsoft-Technologien und ist seit 1997 in der Schulungs- und Zertifizierungsbranche tätig. Als Vorsitzende und CEO von Online Training
LEGO bauen. Das»inoffizielle«Handbuch. von Allan Bedford. 1. Auflage
LEGO bauen Das»inoffizielle«Handbuch von Allan Bedford 1. Auflage LEGO bauen Bedford schnell und portofrei erhältlich bei beck-shop.de DIE FACHBUCHHANDLUNG dpunkt.verlag 2013 Verlag C.H. Beck im Internet:
Tilo Linz ist Vorstand und Mitgründer der imbus AG, einem führenden Lösungsanbieter für Softwaretest und seit mehr als 20 Jahren
Tilo Linz ist Vorstand und Mitgründer der imbus AG, einem führenden Lösungsanbieter für Softwaretest und seit mehr als 20 Jahren im Themengebiet Softwarequalitätssicherung und Softwaretest tätig. Als Gründer
Unit-Tests mit ABAP Unit
D3kjd3Di38lk323nnm Damir Majer Unit-Tests mit ABAP Unit Damir Majer [email protected] Lektorat: Dr. Michael Barabas Copy-Editing: Annette Schwarz, Ditzingen Herstellung und Satz: Frank Heidt Umschlaggestaltung:
Adrian Mouat. ISBN: Buch PDF epub mobi
3nnm Adrian Mouat Übersetzung: Thomas Demmig Überarbeitung und Aktualisierung: Peter Roßbach Lektorat: René Schönfeldt Copy-Editing: Annette Schwarz, Ditzingen Satz: III-satz, www.drei-satz.de Herstellung:
Agile Softwareentwicklung in großen Projekten
D3kjd3Di38lk323nnm Jutta Eckstein Agile Softwareentwicklung in großen Projekten Teams, Prozesse und Technologien Strategien für den Wandel im Unternehmen 2., überarbeitete u. aktualisierte Auflage Jutta
Michael Kurz Martin Marinschek
Michael Kurz studierte Informatik an der Technischen Universität Wien und hat sich seitdem in seiner beruflichen Tätigkeit dem Thema Webentwicklung verschrieben. Seit seinem Wechsel zu IRIAN beschäftigt
Mike Burrows Übersetzer: Florian Eisenberg Wolfgang Wiedenroth www.dpunkt.de/plus
Mike Burrows ist Geschäftsführer und Principal Consultant von David J. Anderson and Associates (djaa.com). In seiner beruflichen Laufbahn, die sich von der Luftfahrt über das Bankwesen, das Energiewesen
Psychologie der Fotografie: Kopf oder Bauch?
Psychologie der Fotografie: Kopf oder Bauch? Über die Kunst Menschen zu fotografieren Bearbeitet von Sven Barnow 1. Auflage 2015. Taschenbuch. VIII, 136 S. Paperback ISBN 978 3 86490 270 3 Format (B x
Dominik Schadow. Java-Web-Security. Sichere Webanwendungen mit Java entwickeln
Dominik Schadow Java-Web-Security Sichere Webanwendungen mit Java entwickeln Dominik Schadow [email protected] Lektorat: René Schönfeldt Copy-Editing: Friederike Daenecke, Zülpich Satz: Da-TeX, Leipzig
Geschichten vom Scrum
Geschichten vom Scrum Von Sprints, Retrospektiven und agilen Werten von Dipl.-Inform. Holger Koschek 2., überarbeitete Auflage Geschichten vom Scrum Koschek schnell und portofrei erhältlich bei beck-shop.de
Agile Softwareentwicklung in großen Projekten
Agile Softwareentwicklung in großen Projekten Teams, Prozesse und Technologien - Strategien für den Wandel im Unternehmen von Jutta Eckstein 2., überarb. u. akt. Aufl. Agile Softwareentwicklung in großen
Geschichten vom Scrum
D3kjd3Di38lk323nnm Holger Koschek Geschichten vom Scrum Von Sprints, Retrospektiven und agilen Werten 2., überarbeitete Auflage Holger Koschek [email protected] http://holger.koschek.eu Lektorat:
Lebendige Webseiten mit Adobe Edge Animate
D3kjd3Di38lk323nnm Lebendige Webseiten mit Adobe Edge Animate Simon Widjaja ist Creative Coder, Autor und IT-Trainer aus purer Leidenschaft. Als erfahrener Flash-Entwickler und EdgeDesigner der ersten
Agile Development vs. Security Requirements
Agile Development vs. Security Requirements Mirco Stickan Agenda Motivation Agile Softwareentwicklung extreme Programming Scrum Sicherheit in agiler Softwareentwicklung Sicherheit in extreme Programming
1 1 des Fotografierens
D3kjd3Di38lk323nnm 1 1 des Fotografierens Khara Plicanic, Das 1X1 des Fotografierens, dpunkt.verlag, ISBN 978-3-86490-183-6 Khara Plicanic Leidenschaft für die Fotografie und ihre humorvolle Art zu erklären
Dr. Carola Lilienthal www.dpunkt.de/plus
Dr. Carola Lilienthal ist Senior-Softwarearchitektin und Mitglied der Geschäftsleitung der WPS Workplace Solutions GmbH in Hamburg. Dort verantwortet sie den Bereich Softwarearchitektur und gibt ihr Wissen
und -implementierungstechniken, Datenbanken & Java.
Gunter Saake ist Professor für Datenbanken und Informationssysteme an der Uni Magdeburg und forscht unter anderem auf den Gebieten Datenbankintegration, digitale Bibliotheken, objektorientierte Informationssysteme
Maik Schmidt. Arduino. Ein schneller Einstieg in die Microcontroller-Entwicklung
Maik Schmidt Arduino Ein schneller Einstieg in die Microcontroller-Entwicklung Lektorat: Dr. Michael Barabas Übersetzung: Volkmar Gronau Copy-Editing: Anja Stiller Satz: G&U Language & Publishing Services
Software modular bauen
Software modular bauen Architektur von langlebigen Softwaresystemen Grundlagen und Anwendung mit OSGi und Java von Ulf Fildebrandt 1. Auflage Software modular bauen Fildebrandt schnell und portofrei erhältlich
Software in 30 Tagen
D3kjd3Di38lk323nnm Ken Schwaber Jeff Sutherland Software in 30 Tagen Wie Manager mit Scrum Wettbewerbsvorteile für ihr Unternehmen schaffen Aus dem Amerikanischen von Stefan Roock Lektorat: Christa Preisendanz
Soft Skills für Softwareentwickler
Soft Skills für Softwareentwickler Uwe Vigenschow arbeitet als Abteilungsleiter bei der Werum IT Solutions AG in Lüneburg, dem international führenden Anbieter von Manufacturing Execution Systems (MES)
Neuronale Netze selbst programmieren
D3kjd3Di38lk323nnm Neuronale Netze selbst programmieren Ein verständlicher Einstieg mit Python Tariq Rashid Deutsche Übersetzung von Frank Langenau Tariq Rashid Lektorat: Alexandra Follenius Übersetzung:
Betriebssysteme. Grundlagen, Konzepte, Systemprogrammierung. von Eduard Glatz. 1. Auflage
Betriebssysteme Grundlagen, Konzepte, Systemprogrammierung von Eduard Glatz 1. Auflage Betriebssysteme Glatz schnell und portofrei erhältlich bei beck-shop.de DIE FACHBUCHHANDLUNG dpunkt.verlag 2005 Verlag
Markus Gaulke www.dpunkt.de/plus
Praxiswissen COBIT Markus Gaulke, Certified Information Systems Auditor (CISA), Certified Information Security Manager (CISM), Certified in the Governance of Enterprise IT (CGEIT), Certified in Risk and
Nachhaltiges IT-Management
D3kjd3Di38lk323nnm Fabian Löser Rüdiger Zarnekow Nachhaltiges IT-Management Unternehmensweite Maßnahmen strategisch planen und erfolgreich umsetzen Fabian Löser ([email protected]) Rüdiger Zarnekow
Die Computerwerkstatt
Klaus Dembowski Die Computerwerkstatt Für PCs, Notebooks, Tablets und Smartphones Klaus Dembowski Lektorat: Gabriel Neumann Herstellung: Nadine Thiele Umschlaggestaltung: Helmut Kraus, www.exclam.de Druck
Das Fuji X100 Handbuch
Michael Diechtierow Das Fuji X100 Handbuch Fotografieren mit der Fujifilm FinePix X100 Dr. Michael Diechtierow [email protected] Lektorat: Gerhard Rossbach, Rudolf Krahm Technische Redaktion: Rudolf Krahm
Sehen und Gestalten. David DuChemins etwas andere Fotoschule. von David DuChemin. 1. Auflage
Sehen und Gestalten David DuChemins etwas andere Fotoschule von David DuChemin 1. Auflage Sehen und Gestalten DuChemin schnell und portofrei erhältlich bei beck-shop.de DIE FACHBUCHHANDLUNG Thematische
Praxiswissen Softwaretest
D3kjd3Di38lk323nnm Praxiswissen Softwaretest Testmanagement Andreas Spillner ist Professor für Informatik an der Hochschule Bremen, Fakultät für Elektrotechnik und Informatik. Er war über 10 Jahre Sprecher
Dipl.-Inform. Sven Röpstorff Dipl.-Kaufm. Robert Wiechmann
Dipl.-Inform. Sven Röpstorff ist freiberuflicher Agiler Projektmanager und Coach mit 17 Jahren Berufserfahrung, Wandler zwischen der traditionellen und der agilen Welt mit Schwerpunkt in agilen Methoden
Testen in Scrum-Projekten
Tilo Linz ist Vorstand und Mitgründer der imbus AG, einem führenden Lösungsanbieter für Softwaretest und seit mehr als 20 Jahren im Themengebiet Softwarequalitätssicherung und Softwaretest tätig. Als Gründer
Das LEGO -MINDSTORMS-EV3-Ideenbuch
Das LEGO -MINDSTORMS-EV3-Ideenbuch 181 einfache Maschinen und clevere Konstruktionen Bearbeitet von Yoshihito Isogawa 1. Auflage 2015. Taschenbuch. VIII, 223 S. Paperback ISBN 978 3 86490 272 7 Format
Allison Tyler Jones, Kinder fotografieren, dpunkt.verlag, ISBN D3kjd3Di38lk323nnm
D3kjd3Di38lk323nnm Allison Tyler Jones verdient Ihren Lebensunterhalt mit authentischen Porträts von Kindern und ihren Familien. Als Co-Autorin hat sie bereits drei Bücher über Fotografie mit verfasst,
ww unk w t.. e p / un plu k s t.de/plus
Torsten Andreas Hoffmann ist Fotograf, Buchautor und leitet Fotoworkshops. Er studierte Kunstpädagogik mit Schwerpunkt Fotografie an der Hochschule für Bildende Künste in Braunschweig. Fotoreisen führten
Continuous Delivery. Der pragmatische Einstieg. von Eberhard Wolff. 1. Auflage. dpunkt.verlag 2014
Continuous Delivery Der pragmatische Einstieg von Eberhard Wolff 1. Auflage dpunkt.verlag 2014 Verlag C.H. Beck im Internet: www.beck.de ISBN 978 3 86490 208 6 Zu Leseprobe schnell und portofrei erhältlich
Inhaltsverzeichnis. 1 Einführung Warum dieses Buch? Struktur und Aufbau Dankeschön Feedback 5
1 Einführung 1 1.1 Warum dieses Buch? 2 1.2 Struktur und Aufbau 3 1.3 Dankeschön 5 1.4 Feedback 5 2 Beispiel: Scrumcoaches.com 7 2.1 Das Projekt 8 2.2 Der Entwicklungsprozess 9 2.3 Die Beteiligten 10 2.4
Agile Softwareentwicklung
Agile Softwareentwicklung Werte, Konzepte und Methoden von Wolf G Bleek, Hennig Wolf 1. Auflage Agile Softwareentwicklung Bleek / Wolf schnell und portofrei erhältlich bei beck-shop.de DIE FACHBUCHHANDLUNG
Konfigurationsmanagement mit Subversion, Ant und Maven
Gunther Popp Konfigurationsmanagement mit Subversion, Ant und Maven Grundlagen für Softwarearchitekten und Entwickler 2., aktualisierte Auflage Gunther Popp [email protected] Lektorat: René Schönfeldt Copy-Editing:
Dr. Michael Diechtierow
Dr. Michael Diechtierow [email protected] Lektorat: Gerhard Rossbach, Rudolf Krahm Technische Redaktion: Rudolf Krahm Korrektorat: Sandra Gottmann Satz: Anna Diechtierow Herstellung: Birgit Bäuerlein Umschlaggestaltung:
Bereits während seines Studiums der Humanmedizin übte Bertram Solcher fotojournalistische Tätigkeiten für regionale
D3kjd3Di38lk323nnm Foto: Katja Solcher Bereits während seines Studiums der Humanmedizin übte Bertram Solcher fotojournalistische Tätigkeiten für regionale und überregionale Tageszeitungen sowie nationale
Peter Fauland. Das FUJIFILM X100T/X100S Handbuch
Peter Fauland Das FUJIFILM X100T/X100S Handbuch Peter Fauland [email protected] Lektorat: Gerhard Rossbach, Rudolf Krahm Copy-Editing: Annette Schwarz, Ditzingen Satz: Anna Diechtierow Herstellung:
VMware vrealize Automation Das Praxisbuch
VMware vrealize Automation Das Praxisbuch Dr. Guido Söldner leitet den Geschäftsbereich Cloud Automation und Software Development bei der Söldner Consult GmbH in Nürnberg. Sein Unternehmen ist auf Virtualisierungsinfrastrukturen
Das "inoffizielle" LEGO-Technic-Buch
Das "inoffizielle" LEGO-Technic-Buch Kreative Bautechniken für realistische Modelle Bearbeitet von Pawel "Sariel" Kmiec 1. Auflage 2013. Taschenbuch. XVIII, 334 S. Paperback ISBN 978 3 86490 067 9 Format
Das FUJIFILM X100T/X100S Handbuch
D3kjd3Di38lk323nnm Peter Fauland Das FUJIFILM X100T/X100S Handbuch Peter Fauland, Das Fujifilm X100T / X100S Handbuch, dpunkt.verlag, ISBN 978-3-86490-249-9 Peter Fauland [email protected] Lektorat:
Personal Kanban. Visualisierung und Planung von Aufgaben, Projekten und Terminen mit dem Kanban-Board. Jim Benson Tonianne DeMaria Barry
Jim Benson Tonianne DeMaria Barry Personal Kanban Visualisierung und Planung von n, Projekten und Terminen mit dem Kanban-Board Übersetzt aus dem Amerikanischen von Meike Mertsch Jim Benson [email protected]
Fotografie: Mehr als nur Blende und Zeit
D3kjd3Di38lk323nnm Jay Maisel Fotografie: Mehr als nur Blende und Zeit Jay Maisel, Fotografie: Mehr als nur Blende und Zeit, dpunkt.verlag, ISBN 978-3-86490-318-2 Lektorat: Gerhard Rossbach, Miriam Metsch
Einleitung. Für wen ist dieses Buch
i Willkommen! Dieses Buch aus der Reihe Schritt für Schritt wurde so konzipiert, dass Sie mit dem Buch leicht und einfach die wesentlichen Aspekte beim Einsatz von vier der Microsoft Office 2016- Apps
Kinder fotografieren
Kinder fotografieren Der Leitfaden für 100%ig authentische Porträts Bearbeitet von Allison Tyler Jones 1. Auflage 2014. Taschenbuch. X, 280 S. Paperback ISBN 978 3 86490 184 3 Format (B x L): 18,5 x 24,5
Über die Herausgeber
Über die Herausgeber Frank R. Lehmann, Paul Kirchberg und Michael Bächle (von links nach rechts) sind Professoren im Studiengang Wirtschaftsinformatik an der Dualen Hochschule Baden-Württemberg (DHBW),
IT-Service-Management mit ITIL 2011 Edition
Roland Böttcher IT-Service-Management mit ITIL 2011 Edition Einführung, Zusammenfassung und Übersicht der elementaren Empfehlungen 3., aktualisierte Auflage Heise Prof. Dr. Roland Böttcher [email protected]
Auf einen Blick. Vorwort Über den Autor Danksagung Einleitung Teil I: Die Rollen Teil II: Die Listen...
Auf einen Blick Vorwort... 9 Über den Autor... 11 Danksagung... 13 Einleitung... 23 Teil I: Die Rollen.... 27 Kapitel 1: Das ist Scrum und so funktioniert es.... 29 Kapitel 2: Der Product Owner.... 35
Im Rahmen seiner Beratertätigkeit veröffentlicht er Artikel und hält Vorträge und Schulungen zu diesen und weiteren Themen.
Dr. Wolf-Gideon Bleek ist seit 1997 in der Softwaretechnik-Gruppe der Universität Hamburg in Forschung und Lehre tätig. Er führt seit 1999 agile Projekte durch und berät Organisationen beim Einsatz agiler
Visual Storytelling. Visuelles Erzählen in PR und Marketing. Bearbeitet von Petra Sammer, Ulrike Heppel
Visual Storytelling Visuelles Erzählen in PR und Marketing Bearbeitet von Petra Sammer, Ulrike Heppel 1. Auflage 2015. Taschenbuch. XII, 330 S. Paperback ISBN 978 3 96009 001 4 Format (B x L): 17,6 x 23
Management von IT-Produkten
Management von IT-Produkten Geschäftsmodelle, Leitlinien und Werkzeugkasten für softwareintensive Systeme und Dienstleistungen Bearbeitet von Georg Herzwurm, Wolfram Pietsch 1. Auflage 2008. Buch. 388
[email protected]
Cora und Georg Banek leben und arbeiten im Raum Mainz, wo sie Mitte 2009 ihr Unternehmen um eine Fotoschule (www.artepictura-akademie.de) erweitert haben. Vorher waren sie hauptsächlich im Bereich der
TCP/IP Grundlagen und Praxis
D3kjd3Di38lk323nnm Gerhard Lienemann Dirk Larisch TCP/IP Grundlagen und Praxis Protokolle, Routing, Dienste, Sicherheit 2., aktualisierte Auflage Heise Gerhard Lienemann / Dirk Larisch, TCP/IP Grundlagen
Praxiswissen TYPO3 CMS 7 LTS
Praxiswissen TYPO3 CMS 7 LTS 8. AUFLAGE Praxiswissen TYPO3 CMS 7 LTS Robert Meyer & Martin Helmich Robert Meyer & Martin Helmich Lektorat: Alexandra Follenius Korrektorat: Sibylle Feldmann Herstellung:
Projektmanagement. Das Scrum - Framework. Version: 5.0 Stand: Autor: Dr. Olaf Boczan
Projektmanagement Das Scrum - Framework Version: 5.0 Stand: 28.05.2017 Autor: Dr. Olaf Boczan Lernziel Sie können mit eigene Worten das Framework Scrum beschreiben. Sie können die Rollen, Aktivitäten und
Barrierefreiheit verstehen und umsetzen
D3kjd3Di38lk323nnm Jan Eric Hellbusch Kerstin Probiesch Barrierefreiheit verstehen und umsetzen Webstandards für ein zugängliches und nutzbares Internet Jan Eric Hellbusch / Kerstin Probiesch, Barrierefreiheit
Android 4.4. Programmieren für Smartphones und Tablets - Grundlagen und fortgeschrittene Techniken. von Arno Becker, Marcus Pant
Android 4.4 Programmieren für Smartphones und Tablets - Grundlagen und fortgeschrittene Techniken von Arno Becker, Marcus Pant 3., akt. u. erw. Aufl dpunkt.verlag 2013 Verlag C.H. Beck im Internet: www.beck.de
Vaughn Vernon Die Übersetzer: Dr. Carola Lilienthal Henning Schwentner
Vaughn Vernon ist ein»software Craftsman«mit mehr als 30 Jahren Erfahrung in Softwaredesign, Entwicklung und Architektur. Seine Leidenschaft ist die Vereinfachung von Softwaredesign und die Implementierung
Das Sony RX100 III Handbuch
Das Sony RX100 III Handbuch Lektorat: Gerhard Rossbach, Rudolf Krahm Layout und Satz: Martin Vieten, Frank Heidt Herstellung: Frank Heidt Umschlaggestaltung: Anna Diechtierow Druck und Bindung: M.P. Media-Print
CNC-Fräsen für Maker und Modellbauer
Christian Rattat arbeitet seit etwa 20 Jahren als Softwareentwickler und begann seine Karriere 1987 auf einem Commodore Amiga 2000. Heute arbeitet er für Großunternehmen im Microsoft- und Unix-Umfeld,
Panoramafotografie: Theorie und Praxis
D3kjd3Di38lk323nnm Harald Woeste Panoramafotografie: Theorie und Praxis 2., aktualisierte und erweiterte Auflage Harald Woeste [email protected] Lektorat: Barbara Lauer, Bonn Copy-Editing: Alexander Reischert
Tilman Beitter Thomas Kärgel André Nähring Andreas Steil Sebastian Zielenski
Tilman Beitter arbeitete mehrere Jahre als Softwareentwickler im ERP-Bereich und ist seit 2010 mit großer Begeisterung für die B1 Systems GmbH als Linux Consultant und Trainer unterwegs. Seine Themenschwerpunkte
Porträtfotografie. Professionelle Porträts durch gekonnte Lichtführung und Inszenierung. Glenn Rand. Tim Meyer
D3kjd3Di38lk323nnm Glenn Rand. Tim Meyer Porträtfotografie Professionelle Porträts durch gekonnte Lichtführung und Inszenierung Glenn Rand, Porträtfotografie, dpunkt.verlag, ISBN 978-3-89864-665-9 Glenn
Die menschliche Seite des Projekterfolgs
D3kjd3Di38lk323nnm Peter Siwon Die menschliche Seite des Projekterfolgs Was Softwerker über (verborgene) Denkautomatismen und -modelle bei der Projektarbeit wissen müssen Peter Siwon, Die menschliche Seite
Pixel & Vektor. Kreative Grafiken mit Illustrator und Photoshop Für CS5 und CS4. Katharina Sckommodau
D3kjd3Di38lk323nnm Katharina Sckommodau Pixel & Vektor Kreative Grafiken mit Illustrator und Photoshop Für CS5 und CS4 Katharina Sckommodau [email protected] Lektorat: Barbara Lauer, Bonn Copy-Editing:
Projektarbeit zwischen Effizienzdruck und Qualitätsanforderungen
Projektarbeit zwischen Effizienzdruck und Qualitätsanforderungen Beiträge zur Konferenz >>interpm
