<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Komplexität Archive - CEOsBay</title>
	<atom:link href="https://ceosbay.com/tag/komplexitaet/feed/" rel="self" type="application/rss+xml" />
	<link>https://ceosbay.com/tag/komplexitaet/</link>
	<description>It&#039;s all about Tech</description>
	<lastBuildDate>Sun, 15 Oct 2023 08:43:46 +0000</lastBuildDate>
	<language>de</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.9.1</generator>

<image>
	<url>https://i0.wp.com/ceosbay.com/wp-content/uploads/2022/11/image.jpg?fit=32%2C32&#038;ssl=1</url>
	<title>Komplexität Archive - CEOsBay</title>
	<link>https://ceosbay.com/tag/komplexitaet/</link>
	<width>32</width>
	<height>32</height>
</image> 
<site xmlns="com-wordpress:feed-additions:1">211828771</site>	<item>
		<title>Ursache-Wirkungs-Graph-Analyse &#8211; Verstehen durch Vernetzen</title>
		<link>https://ceosbay.com/2023/10/15/ursache-wirkungs-graph-analyse-verstehen-durch-vernetzen/</link>
					<comments>https://ceosbay.com/2023/10/15/ursache-wirkungs-graph-analyse-verstehen-durch-vernetzen/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Sun, 15 Oct 2023 08:43:42 +0000</pubDate>
				<category><![CDATA[Bildung]]></category>
		<category><![CDATA[Datenvisualisierung]]></category>
		<category><![CDATA[Datenwissenschaft]]></category>
		<category><![CDATA[Abhängigkeiten]]></category>
		<category><![CDATA[Abstraktionsvermögen]]></category>
		<category><![CDATA[Analyse-Tool]]></category>
		<category><![CDATA[Analysemethodik]]></category>
		<category><![CDATA[Analytische Techniken]]></category>
		<category><![CDATA[Analytisches Denken]]></category>
		<category><![CDATA[Beziehungsnetze]]></category>
		<category><![CDATA[Diagrammerstellung]]></category>
		<category><![CDATA[Diagrammtechniken]]></category>
		<category><![CDATA[Effektdarstellung]]></category>
		<category><![CDATA[Einflussfaktoren]]></category>
		<category><![CDATA[Entscheidungsfindung]]></category>
		<category><![CDATA[Entscheidungshilfe]]></category>
		<category><![CDATA[Faktorenidentifikation]]></category>
		<category><![CDATA[Grafische Darstellung]]></category>
		<category><![CDATA[Grapheninterpretation]]></category>
		<category><![CDATA[Graphentechnik]]></category>
		<category><![CDATA[Interaktionen]]></category>
		<category><![CDATA[Interdependenzen]]></category>
		<category><![CDATA[Ishikawa-Diagramm]]></category>
		<category><![CDATA[Kausalanalyse]]></category>
		<category><![CDATA[Kausalität]]></category>
		<category><![CDATA[Knoten]]></category>
		<category><![CDATA[Komplexität]]></category>
		<category><![CDATA[Modellierung]]></category>
		<category><![CDATA[Netzwerkdiagramm]]></category>
		<category><![CDATA[Problemdiagnostik]]></category>
		<category><![CDATA[Problemfelder]]></category>
		<category><![CDATA[Problemlösung]]></category>
		<category><![CDATA[Prozessoptimierung]]></category>
		<category><![CDATA[Prozessverfolgung]]></category>
		<category><![CDATA[Qualitätsmanagement]]></category>
		<category><![CDATA[Strukturanalyse]]></category>
		<category><![CDATA[Systemanalyse]]></category>
		<category><![CDATA[Systemdynamik]]></category>
		<category><![CDATA[Systemische Perspektive]]></category>
		<category><![CDATA[Systemverständnis]]></category>
		<category><![CDATA[Ursache-Wirkungs-Analyse]]></category>
		<category><![CDATA[Ursache-Wirkungs-Beziehung]]></category>
		<category><![CDATA[Ursachenidentifikation]]></category>
		<category><![CDATA[Verbindungen]]></category>
		<category><![CDATA[Verknüpfungsanalyse]]></category>
		<category><![CDATA[Visualisierungsstrategie]]></category>
		<category><![CDATA[Wechselwirkungen]]></category>
		<category><![CDATA[Wirkungsanalyse]]></category>
		<category><![CDATA[Zusammenhänge]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=2780</guid>

					<description><![CDATA[<p>Die Welt ist voller miteinander verbundener Phänomene, und um sie besser zu verstehen, braucht es oft den Blick auf die zugrunde liegenden Ursache-Wirkungs-Zusammenhänge. In diesem Kontext hat das Ursache-Wirkungs-Diagramm eine besondere Bedeutung erlangt. Es stellt &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/10/15/ursache-wirkungs-graph-analyse-verstehen-durch-vernetzen/">Ursache-Wirkungs-Graph-Analyse &#8211; Verstehen durch Vernetzen</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p>Die Welt ist voller miteinander verbundener Phänomene, und um sie besser zu verstehen, braucht es oft den Blick auf die zugrunde liegenden Ursache-Wirkungs-Zusammenhänge. In diesem Kontext hat das Ursache-Wirkungs-Diagramm eine besondere Bedeutung erlangt. Es stellt grafisch Ursachen dar, die ein Ergebnis beeinflussen, und hilft dabei, alle Problemursachen zu identifizieren und ihre Abhängigkeiten zu visualisieren.</p>



<h3 class="wp-block-heading">Was ist die Ursache-Wirkungs-Graph-Analyse?</h3>



<p>Bei der Ursache-Wirkungs-Graph-Analyse handelt es sich um eine visuelle Darstellungsform, die hilft, komplexe Zusammenhänge zwischen unterschiedlichen Faktoren zu verstehen. Mit Hilfe von Knoten und Verbindungen lassen sich Ursachen und ihre jeweiligen Auswirkungen grafisch abbilden. So kann man nicht nur isolierte Einzelfaktoren betrachten, sondern auch die Wechselwirkungen und Abhängigkeiten zwischen mehreren Faktoren.</p>



<h3 class="wp-block-heading">Geschichte der Ursache-Wirkungs-Graph-Analyse</h3>



<p>Die Idee, komplexe Zusammenhänge grafisch darzustellen, reicht weit zurück. Bereits in der Antike nutzten Philosophen Diagramme, um logische Schlüsse zu ziehen. Doch die moderne Form der Ursache-Wirkungs-Graph-Analyse, insbesondere das Ursache-Wirkungs-Diagramm, erlebte in den 1940er Jahren eine bedeutende Weiterentwicklung durch den japanischen Wissenschaftler Kaoru Ishikawa. Dieses nach ihm benannte Ishikawa-Diagramm diente ursprünglich im Qualitätsmanagement zur Analyse von Qualitätsproblemen und deren Ursachen. Schnell erkannte man jedoch das Potenzial dieses Ansatzes und übertrug ihn auf andere Problemfelder. So fand das Ishikawa-Diagramm weltweite Verbreitung und dient heute in vielfältigen Bereichen als Tool zur Analyse und Problemlösung.</p>



<h3 class="wp-block-heading">Wie geht man am besten vor?</h3>



<ol class="wp-block-list">
<li><strong>Identifizierung der Hauptursachen:</strong> Bevor man einen Graphen erstellt, identifiziert man die Hauptursachen oder Faktoren, die das zu analysierende System beeinflussen.</li>



<li><strong>Bestimmung der Wirkungen:</strong> Jede Ursache hat eine oder mehrere Wirkungen. Diese muss man identifiziert und im Graphen dargestellt werden.</li>



<li><strong>Erstellung des Graphen:</strong> Mit Hilfe von speziellen Software-Tools oder auch einfach per Hand zeichnet man die Ursachen und Wirkungen in Form von Knoten und verbindet sie durch Pfeile, die die Beziehungen anzeigen.</li>



<li><strong>Analyse des Graphen:</strong> Nach der Erstellung des Graphen analysiert man die Wechselwirkungen und Abhängigkeiten, um Schlussfolgerungen zu ziehen oder Lösungsansätze zu entwickeln.</li>
</ol>



<h3 class="wp-block-heading">Beispiele für den Einsatz der Ursache-Wirkungs-Graph-Analyse</h3>



<ul class="wp-block-list">
<li><strong>Umweltforschung:</strong> Bei der Untersuchung von Ökosystemen kann die Analyse helfen, die Auswirkungen menschlicher Eingriffe oder natürlicher Veränderungen zu verstehen.</li>



<li><strong>Produktentwicklung:</strong> In der Industrie lassen sich mit der Analyse mögliche Probleme in der Fertigung oder im Design identifizieren.</li>



<li><strong>Gesundheitswesen:</strong> Ärzte und Forscher nutzen die Methode, um die Wechselwirkungen zwischen verschiedenen Krankheitsursachen und Symptomen besser zu verstehen.</li>



<li><strong>Wirtschaftsforschung:</strong> In der Wirtschaft können Unternehmen die Analyse nutzen, um Marktveränderungen, Kundennachfrage oder Risikofaktoren zu analysieren.</li>
</ul>



<h3 class="wp-block-heading">Welche Software eignet sich dafür?</h3>



<ol class="wp-block-list">
<li><strong>Microsoft Visio:</strong> Ein weit verbreitetes Tool für Diagramme und Grafiken. Es bietet verschiedene Vorlagen, einschließlich des Ishikawa-Diagramms.</li>



<li><strong>Lucidchart:</strong> Ein cloudbasiertes Diagramm-Tool, das viele Vorlagen und Integrationen bietet und sich gut für kollaborative Arbeiten eignet.</li>



<li><strong>MindManager:</strong> Ursprünglich ein Mind-Mapping-Tool, das sich aber auch gut für die Erstellung von Ursache-Wirkungs-Diagrammen eignet.</li>



<li><strong>SmartDraw:</strong> Ein weiteres Diagramm-Tool mit einer großen Auswahl an Vorlagen.</li>



<li><strong>Draw.io (jetzt bekannt als <a href="https://app.diagrams.net">diagrams.net</a>):</strong> Ein kostenloses, webbasiertes Tool zur Diagrammerstellung, das auch Vorlagen für Ursache-Wirkungs-Diagramme bereithält.</li>



<li><strong>Miro:</strong> Ein Online-Whiteboard-Tool, das verschiedene Diagramm-Vorlagen bietet und besonders für Teamarbeit und Brainstorming geeignet ist.</li>
</ol>



<p>Diese Tools bieten nicht nur Vorlagen für Ursache-Wirkungs-Diagramme, sondern unterstützen auch eine Vielzahl anderer Diagrammtypen und haben oft Kollaborationsfunktionen, sodass Teams in Echtzeit daran arbeiten können.</p>



<h3 class="wp-block-heading">Fazit</h3>



<p>Zusammenfassend bietet die Ursache-Wirkungs-Graph-Analyse ein mächtiges Werkzeug, um komplexe Systeme zu verstehen und fundierte Entscheidungen zu treffen. Mit ihrer Hilfe lassen sich nicht nur Probleme identifizieren, sondern auch Lösungen entwickeln und Potenziale ausschöpfen.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/10/15/ursache-wirkungs-graph-analyse-verstehen-durch-vernetzen/">Ursache-Wirkungs-Graph-Analyse &#8211; Verstehen durch Vernetzen</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2023/10/15/ursache-wirkungs-graph-analyse-verstehen-durch-vernetzen/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">2780</post-id>	</item>
		<item>
		<title>Domain Driven Design (DDD) &#8211; Die Kunst der Softwarearchitektur</title>
		<link>https://ceosbay.com/2023/08/03/domain-driven-design-ddd-die-kunst-der-softwarearchitektur/</link>
					<comments>https://ceosbay.com/2023/08/03/domain-driven-design-ddd-die-kunst-der-softwarearchitektur/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Thu, 03 Aug 2023 20:12:00 +0000</pubDate>
				<category><![CDATA[Agile]]></category>
		<category><![CDATA[Automatisierung]]></category>
		<category><![CDATA[Design]]></category>
		<category><![CDATA[DevOps]]></category>
		<category><![CDATA[Entwicklung]]></category>
		<category><![CDATA[Programmieren]]></category>
		<category><![CDATA[Sicherheit]]></category>
		<category><![CDATA[Softwarequalität]]></category>
		<category><![CDATA[Testautomatisierung]]></category>
		<category><![CDATA[Testing]]></category>
		<category><![CDATA[Bounded Context]]></category>
		<category><![CDATA[Context Mapping]]></category>
		<category><![CDATA[Dev]]></category>
		<category><![CDATA[Domain Driven Design]]></category>
		<category><![CDATA[Eric Evans]]></category>
		<category><![CDATA[Geschäftsdomäne]]></category>
		<category><![CDATA[Kommunikationsbarrieren]]></category>
		<category><![CDATA[Komplexität]]></category>
		<category><![CDATA[Model Driven Design]]></category>
		<category><![CDATA[Ops]]></category>
		<category><![CDATA[Ressourcenaufwand]]></category>
		<category><![CDATA[Skalierung]]></category>
		<category><![CDATA[Softwareentwicklung]]></category>
		<category><![CDATA[Teamzusammenarbeit]]></category>
		<category><![CDATA[Ubiquitous Language]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=2109</guid>

					<description><![CDATA[<p>Domain Driven Design (DDD) ist ein entscheidender Faktor, um die Komplexität in Softwareprojekten zu bewältigen. Man hat diesen Ansatz entwickelt, um Softwareentwicklungsteams dabei zu helfen, qualitativ hochwertige und robuste Anwendungen zu entwickeln. In diesem Beitrag &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/08/03/domain-driven-design-ddd-die-kunst-der-softwarearchitektur/">Domain Driven Design (DDD) &#8211; Die Kunst der Softwarearchitektur</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p>Domain Driven Design (DDD) ist ein entscheidender Faktor, um die Komplexität in Softwareprojekten zu bewältigen. Man hat diesen Ansatz entwickelt, um Softwareentwicklungsteams dabei zu helfen, qualitativ hochwertige und robuste Anwendungen zu entwickeln. In diesem Beitrag versuche ich, die Entstehung dieses Konzeptes zu erläutern und praktische Herangehensweisen zur Umsetzung zu ermitteln.</p>



<h2 class="wp-block-heading">Was ist Domain Driven Design?</h2>



<p>Domain Driven Design ist ein Ansatz zur Softwareentwicklung, der den Fokus auf die Geschäftslogik und -struktur legt, die in der sogenannten &#8222;Domäne&#8220; existieren. Es konzentriert sich darauf, ein tieferes Verständnis des Problembereichs und der Geschäftsanforderungen zu erlangen, bevor es auf die technischen Aspekte eingeht. Das primäre Ziel ist, die Komplexität durch die Modellierung einer Software um das Herzstück der realen Weltprobleme zu bewältigen.</p>



<h2 class="wp-block-heading">Die Entstehung von Domain Driven Design</h2>



<p>Domain Driven Design wurde von Eric Evans in seinem Buch &#8222;Domain-Driven Design: Tackling Complexity in the Heart of Software&#8220; im Jahr 2003 vorgestellt. Evans hat die Grundlagen und Prinzipien von DDD detailliert beschrieben und dabei den Fokus auf die Zusammenarbeit zwischen technischen Experten und Domänenexperten gelegt.</p>



<h2 class="wp-block-heading">Wie lässt es sich umsetzen?</h2>



<p>Die Implementierung kann in vier Hauptschritten erfolgen:</p>



<ol class="wp-block-list">
<li><strong>Ubiquitous Language:</strong> Dies ist eine gemeinsame Sprache, die von allen Teammitgliedern genutzt wird, um Missverständnisse zwischen den technischen Mitgliedern und den Domänenexperten zu vermeiden. Diese gemeinsame Sprache wird sowohl im Code als auch in den Gesprächen verwendet.</li>



<li><strong>Model Driven Design:</strong> Hier erstellt man ein Modell oder eine Darstellung der Domäne. Dieses Modell verwendet man, um das System zu entwerfen und zu implementieren. Es hilft, das Verständnis und die Kommunikation zwischen allen Teammitgliedern zu verbessern.</li>



<li><strong>Bounded Context:</strong> Hierbei handelt es sich um die Grenze oder den Bereich, in dem ein bestimmtes Modell gilt. Durch die Definition von Bounded Contexts kann man die Komplexität des Systems reduzieren und das Verständnis der Domäne verbessern.</li>



<li><strong>Context Mapping:</strong> Dies ist der Prozess, in dem man die Beziehungen und Interaktionen zwischen verschiedenen Bounded Contexts definiert und ein gewisses Verständnis dafür entwickelt.</li>
</ol>



<h2 class="wp-block-heading">Was ist bei der Umsetzung zu beachten?</h2>



<p>Es ist wichtig, einige Schlüsselelemente im Auge zu behalten, um eine erfolgreiche Umsetzung von Domain Driven Design zu gewährleisten. Ein gründliches Verständnis der Geschäftsdomäne ist entscheidend. Außerdem ist die Zusammenarbeit zwischen den Domänenexperten und den technischen Experten von großer Bedeutung.</p>



<h2 class="wp-block-heading">Fazit</h2>



<p>Domain Driven Design ist ein wirkungsvolles Werkzeug zur Bewältigung von Komplexität in Softwareprojekten. Es bietet einen strukturierten Ansatz zur Modellierung der Geschäftslogik und zur Entwicklung von robusten, wartbaren Softwarelösungen. Durch eine engagierte Zusammenarbeit und den Aufbau eines gemeinsamen Verständnisses der Domäne kann DDD dazu beitragen, die Herausforderungen in der Softwareentwicklung effektiv zu meistern.</p>



<p>Obwohl Domain Driven Design in komplexen Projekten viele Vorteile bietet, sind damit auch Herausforderungen verbunden. DDD ist ein komplexer Ansatz, der ein tiefgehendes Verständnis der Geschäftsdomäne und technisches Know-how erfordert, was bei neuen Teams zu Schwierigkeiten führen kann. Der Initialaufwand, ein geteiltes Modell der Domäne zu erstellen und effektive Kommunikationskanäle einzurichten, kann zeit- und ressourcenintensiv sein. Es ist am effektivsten in großen, komplexen Projekten, aber für kleinere, weniger komplexe Projekte kann es ineffizient sein. Die Skalierung in großen Organisationen und die Koordination verschiedener Bounded Contexts kann zu Herausforderungen führen. Zudem erfordert es ein hohes Maß an Zusammenarbeit und Verständnis unter allen Teammitgliedern, was in einigen Teams schwer zu erreichen sein könnte. Die Erstellung einer Ubiquitous Language kann aufgrund von Kommunikationsbarrieren in vielfältigen Teams ebenfalls eine Herausforderung darstellen.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/08/03/domain-driven-design-ddd-die-kunst-der-softwarearchitektur/">Domain Driven Design (DDD) &#8211; Die Kunst der Softwarearchitektur</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2023/08/03/domain-driven-design-ddd-die-kunst-der-softwarearchitektur/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">2109</post-id>	</item>
		<item>
		<title>Clean Code &#8211; Elegante Lösungen für effiziente und wartungsfreundliche Software</title>
		<link>https://ceosbay.com/2023/04/11/erklaerung-clean-code/</link>
					<comments>https://ceosbay.com/2023/04/11/erklaerung-clean-code/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Tue, 11 Apr 2023 19:53:02 +0000</pubDate>
				<category><![CDATA[Agile]]></category>
		<category><![CDATA[Automatisierung]]></category>
		<category><![CDATA[Bildung]]></category>
		<category><![CDATA[DevOps]]></category>
		<category><![CDATA[Entwicklung]]></category>
		<category><![CDATA[Internet]]></category>
		<category><![CDATA[Programmieren]]></category>
		<category><![CDATA[Testing]]></category>
		<category><![CDATA[Website]]></category>
		<category><![CDATA[Architekt]]></category>
		<category><![CDATA[Bob]]></category>
		<category><![CDATA[Clean]]></category>
		<category><![CDATA[CleanCode]]></category>
		<category><![CDATA[Code]]></category>
		<category><![CDATA[Coder]]></category>
		<category><![CDATA[Continuous]]></category>
		<category><![CDATA[Craftmanship]]></category>
		<category><![CDATA[Deployment]]></category>
		<category><![CDATA[Development]]></category>
		<category><![CDATA[DRY]]></category>
		<category><![CDATA[Einfachheit]]></category>
		<category><![CDATA[Erleichterung]]></category>
		<category><![CDATA[Fazit]]></category>
		<category><![CDATA[Fehler]]></category>
		<category><![CDATA[Fehlerhandhabung]]></category>
		<category><![CDATA[Kommentar]]></category>
		<category><![CDATA[Kommentare]]></category>
		<category><![CDATA[Komplex]]></category>
		<category><![CDATA[Komplexität]]></category>
		<category><![CDATA[Leichter]]></category>
		<category><![CDATA[Lesbarkeit]]></category>
		<category><![CDATA[Modularität]]></category>
		<category><![CDATA[Praxis]]></category>
		<category><![CDATA[Prinzipien]]></category>
		<category><![CDATA[Probleme]]></category>
		<category><![CDATA[Programmierung]]></category>
		<category><![CDATA[Qualität]]></category>
		<category><![CDATA[Responsibility]]></category>
		<category><![CDATA[Single]]></category>
		<category><![CDATA[SRP]]></category>
		<category><![CDATA[TDD]]></category>
		<category><![CDATA[Team]]></category>
		<category><![CDATA[Team Work]]></category>
		<category><![CDATA[Test]]></category>
		<category><![CDATA[Verständnis]]></category>
		<category><![CDATA[Wiederverwendbarkeit]]></category>
		<category><![CDATA[Work]]></category>
		<category><![CDATA[Zeitdruck]]></category>
		<category><![CDATA[Zusammenarbeit]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=1398</guid>

					<description><![CDATA[<p>In der Welt der Softwareentwicklung hat sich der Begriff &#8222;Clean Code&#8220; zu einem wichtigen Leitprinzip entwickelt. Die Idee, dass sauberer, gut strukturierter und leicht verständlicher Code zu besseren und wartungsfreundlicheren Softwareprodukten führt, ist mittlerweile weit &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/04/11/erklaerung-clean-code/">Clean Code &#8211; Elegante Lösungen für effiziente und wartungsfreundliche Software</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p>In der Welt der Softwareentwicklung hat sich der Begriff &#8222;Clean Code&#8220; zu einem wichtigen Leitprinzip entwickelt. Die Idee, dass sauberer, gut strukturierter und leicht verständlicher Code zu besseren und wartungsfreundlicheren Softwareprodukten führt, ist mittlerweile weit verbreitet. Heute geht es um das Konzept von Clean Code, warum es wichtig ist und wie man es in der Praxis umsetzen kann.</p>



<h3 class="wp-block-heading">Was ist Clean Code?</h3>



<p>Clean Code bezieht sich auf den Ansatz, Code so zu schreiben, dass er leicht verständlich, wartbar und erweiterbar ist. Das Konzept wurde von Robert C. Martin, auch bekannt als &#8222;Uncle Bob&#8220;, in seinem Buch &#8222;Clean Code: A Handbook of Agile Software Craftsmanship&#8220; populär gemacht. Im Kern geht es darum, Softwareentwicklung als Handwerk zu betrachten und stets auf hohe Qualität und Präzision in der Codegestaltung zu achten.</p>



<h3 class="wp-block-heading">Warum ist es wichtig?</h3>



<p>Sauberer Code bietet verschiedene Vorteile, sowohl für den Entwickler selbst, für das gesamte Team und meiner Meinung nach auch für die ganze Welt.</p>



<ul class="wp-block-list">
<li>Verständlichkeit: Clean Code ist einfacher zu lesen und zu verstehen. Das hilft Entwicklern, sich schneller mit dem Code vertraut zu machen und Fehler oder Verbesserungsmöglichkeiten schneller zu erkennen.</li>



<li>Wartbarkeit: Sauberer Code ist leichter zu warten, da er klar strukturiert und weniger anfällig für Fehler oder unerwartete Probleme ist.</li>



<li>Effizienz: Da Clean Code einfacher zu verstehen ist, kann das Team schneller arbeiten und die Produktivität steigt.</li>



<li>Zusammenarbeit: Ein sauberer Code erleichtert die Zusammenarbeit im Team, da jeder den Code anderer Entwickler leichter lesen und verstehen kann.</li>
</ul>



<h3 class="wp-block-heading">Prinzipien von Clean Code</h3>



<p>Es gibt viele Prinzipien und Praktiken, die beim Schreiben von sauberem Code helfen können. Einige der wichtigsten sind:</p>



<ul class="wp-block-list">
<li>Lesbarkeit: Der Code sollte leicht lesbar und verständlich sein. Das bedeutet, dass man Variablen, Funktionen und Klassen sinnvoll benamt und ihre Funktion leicht erkennbar ist. Kommentare setzt man sparsam ein, um den Code nicht zu überfrachten.</li>
</ul>



<ul class="wp-block-list">
<li>Einfachheit: Man hält den Code so einfach wie möglich, ohne unnötige Komplexität oder Verwirrung. Das bedeutet, dass man sich auf das Wesentliche konzentrieren und abstrakte Konzepte wie Design Patterns oder Funktionen nur verwendet, wenn sie tatsächlich nützlich sind.</li>
</ul>



<ul class="wp-block-list">
<li>Modularität: Man teilt den Code in kleine unabhängige Module auf, die jeweils eine bestimmte Funktion erfüllen. Dadurch wird der Code leichter zu verstehen und zu warten.</li>
</ul>



<ul class="wp-block-list">
<li>Wiederverwendbarkeit: Man schreibt den Code so, dass die Wiederverwendbarkeit gewährleistet ist. Dies bedeutet, dass Funktionen oder Klassen, die eine bestimmte Aufgabe erfüllen, generisch genug sind, um in verschiedenen Situationen Verwendung zu finden.</li>
</ul>



<h3 class="wp-block-heading">Clean Code in der Praxis</h3>



<p>Hier sind einige konkrete Schritte, die man beim Schreiben von Clean Code in der Praxis beachten sollte:</p>



<ul class="wp-block-list">
<li>Variablen-, Funktions- und Klassennamen: Man wählt sinnvolle, beschreibende Namen, die klar machen, was eine Variable, Funktion oder Klasse macht. Die Vermeidung von Abkürzungen oder unverständliche Namen ist eines der obersten Gebote.</li>
</ul>



<ul class="wp-block-list">
<li>Single Responsibility Principle (SRP): Jede Funktion oder Klasse sollte nur eine einzige Verantwortung haben. Dies bedeutet, dass sie nur einen Aspekt des Problems lösen sollte, um den Code einfacher und leichter zu warten.</li>
</ul>



<ul class="wp-block-list">
<li>Funktionen und Methoden: Man hält Funktionen und Methoden kurz und konzentrieren sich darauf, dass sie eine einzige Aufgabe erfüllen. Eine Funktion oder Methode sollte in der Regel nicht länger als 20 Zeilen sein, um ihre Verständlichkeit zu gewährleisten.</li>
</ul>



<ul class="wp-block-list">
<li>KISS (Keep It Simple, Stupid) Prinzip: Man versucht, den Code so einfach wie möglich zu halten und unnötige Komplexität zu vermeiden. Wenn es eine einfachere Lösung gibt, zieht man diese der komplexeren vor.</li>
</ul>



<ul class="wp-block-list">
<li>Don&#8217;t Repeat Yourself (DRY) Prinzip: Man vermeidet doppelten Code, indem man wiederverwendbare Funktionen oder Klassen erstellt. Das verringert die Wahrscheinlichkeit von Fehlern und macht den Code leichter zu warten.</li>
</ul>



<ul class="wp-block-list">
<li>Code-Kommentare: Man sollte Kommentare dazu verwenden, den Zweck und die Funktionsweise von Code-Teilen zu erläutern, die nicht sofort offensichtlich sind. Man sollte jedoch nicht zu viele Kommentare schreiben, da dies den Code unübersichtlich machen kann.</li>
</ul>



<ul class="wp-block-list">
<li>Fehlerbehandlung: Die Implementierung einer angemessenen Fehlerbehandlung sollte unabdingbar sein, um unerwartete Probleme zu erkennen und angemessen darauf zu reagieren. Die Verwendung von Exceptions und try-catch-Blöcken, kann eine gute Lösung darstellen, um Fehler abzufangen und entsprechend darauf zu reagieren.</li>
</ul>



<ul class="wp-block-list">
<li>Testgetriebene Entwicklung (<a href="https://ceosbay.com/2023/03/13/erklaerung-test-driven-development/" target="_blank" rel="noreferrer noopener">TDD</a>): Man schreibt zuerst Tests, bevor man den eigentlichen Code entwickelt. Auf diese Weise kann man sicherstellen, dass die Implementierung den gewünschten Anforderungen entspricht und weniger fehleranfällig ist. Siehe hierzu meinen <a href="https://ceosbay.com/2023/03/13/erklaerung-test-driven-development/" target="_blank" rel="noreferrer noopener">Beitrag über Test Driven Development</a>.</li>
</ul>



<ul class="wp-block-list">
<li>Kontinuierliche Integration (CI) und Continuous Deployment (CD): Man verwendet CI/CD-Tools, um den Code regelmäßig zu testen und automatisch zu deployen. Dies stellt sicher, dass der Code immer auf dem neuesten Stand ist und das man potenzielle Probleme schnell erkennen kann.</li>
</ul>



<h3 class="wp-block-heading">Fazit</h3>



<p>Im Grunde genommen ist dies für mich eine relativ neue Angelegenheit, da ich in der Vergangenheit schon recht of den Code einfach reingehackt habe, da ich mich unter Zeitdruck gefühlt habe. Ich ertappe mich hin und wieder immer noch dabei und dies sehr oft, wie ich auf alte Gewohnheiten und Muster zurückgreife. Doch dies sollte sich hoffentlich in den nächsten Monaten und Jahren auf ein Minimum reduzieren lassen. Ich bin davon überzeugt, dass Clean Code ein wesentlicher Bestandteil einer erfolgreichen Softwareentwicklung ist. Indem man sich auf Lesbarkeit, Einfachheit, Modularität und Wiederverwendbarkeit konzentriert, kann man den eigenen Code nicht nur leichter verstehen, sondern auch schneller und effizienter arbeiten. Durch die Anwendung der oben genannten Prinzipien und Praktiken kann man den Code verbessern und letztendlich zu erfolgreichen, wartungsfreundlichen Softwareprodukten beitragen.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/04/11/erklaerung-clean-code/">Clean Code &#8211; Elegante Lösungen für effiziente und wartungsfreundliche Software</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2023/04/11/erklaerung-clean-code/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">1398</post-id>	</item>
		<item>
		<title>Refactoring &#8211; Optimierung und Evolution für nachhaltigen Code</title>
		<link>https://ceosbay.com/2023/04/10/erklaerung-refactoring/</link>
					<comments>https://ceosbay.com/2023/04/10/erklaerung-refactoring/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Mon, 10 Apr 2023 09:15:17 +0000</pubDate>
				<category><![CDATA[Agile]]></category>
		<category><![CDATA[DevOps]]></category>
		<category><![CDATA[Entwicklung]]></category>
		<category><![CDATA[Internet]]></category>
		<category><![CDATA[Programmieren]]></category>
		<category><![CDATA[Testing]]></category>
		<category><![CDATA[Website]]></category>
		<category><![CDATA[Aufwand]]></category>
		<category><![CDATA[Code]]></category>
		<category><![CDATA[Dev]]></category>
		<category><![CDATA[Entwicklungsumgebung]]></category>
		<category><![CDATA[Funktionalität]]></category>
		<category><![CDATA[HAL]]></category>
		<category><![CDATA[Inkonsistenz]]></category>
		<category><![CDATA[Inkonsistenzen]]></category>
		<category><![CDATA[Komplex]]></category>
		<category><![CDATA[Komplexität]]></category>
		<category><![CDATA[Lesbarkeit]]></category>
		<category><![CDATA[Modular]]></category>
		<category><![CDATA[Ops]]></category>
		<category><![CDATA[Optimal]]></category>
		<category><![CDATA[Optimierung]]></category>
		<category><![CDATA[Performance]]></category>
		<category><![CDATA[Practices]]></category>
		<category><![CDATA[Praktisch]]></category>
		<category><![CDATA[Praxis]]></category>
		<category><![CDATA[Probleme]]></category>
		<category><![CDATA[Prozess]]></category>
		<category><![CDATA[Qualität]]></category>
		<category><![CDATA[Qualitätsstandards]]></category>
		<category><![CDATA[Refactor]]></category>
		<category><![CDATA[Schulden]]></category>
		<category><![CDATA[Sicherstellen]]></category>
		<category><![CDATA[Smell]]></category>
		<category><![CDATA[Smells]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[Softwareentwicklung]]></category>
		<category><![CDATA[Standards]]></category>
		<category><![CDATA[Team]]></category>
		<category><![CDATA[Technik]]></category>
		<category><![CDATA[tests]]></category>
		<category><![CDATA[Verstand]]></category>
		<category><![CDATA[Verstehen]]></category>
		<category><![CDATA[Wartbarkeit]]></category>
		<category><![CDATA[Websiteentwicklung]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=1357</guid>

					<description><![CDATA[<p>Refactoring ist eine kontinuierliche Praxis im Softwareentwicklungsprozess, die es ermöglicht, die Struktur und Lesbarkeit des Codes zu verbessern, ohne dessen Funktionalität zu verändern. Dieser Prozess ermöglicht es, den Code sauber, wartbar und skalierbar zu halten. &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/04/10/erklaerung-refactoring/">Refactoring &#8211; Optimierung und Evolution für nachhaltigen Code</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p>Refactoring ist eine kontinuierliche Praxis im Softwareentwicklungsprozess, die es ermöglicht, die Struktur und Lesbarkeit des Codes zu verbessern, ohne dessen Funktionalität zu verändern. Dieser Prozess ermöglicht es, den Code sauber, wartbar und skalierbar zu halten.</p>



<h3 class="wp-block-heading">Definition</h3>



<p>Der Begriff wurde zum ersten Mal in einer Arbeit von Ralph Johnson und William Opdyke 1990 gebraucht (Refactoring: An aid in designing application frameworks and evolving object-oriented systems. In: Proceedings of Symposion on Object-Oriented Programming Emphasizing Practical Applications (SOOPPA), September 1990). Opdyke promovierte 1992 zu dem Thema. Sie entwickelten die Idee einer Software-Refactory, die das Umgestalten (eben das Refactoring) von Computerprogrammen erleichtern sollte. Die unzutreffende Übersetzung Refaktorisierung stammt aus einer Verwechslung mit einer häufig zitierten Analogie, die ursprünglich nicht Begriffsinhalt war: Refactoring ist eine Art, ein Programm so zu modifizieren, dass man verborgene Strukturen offenlegt, ohne die Funktionalität zu ändern. Dies, so der (fälschliche) Analogieschluss, entspreche dem Vorgehen der Faktorisierung von Polynomen in der Mathematik. Bin aber kein Mathematiker 😉</p>



<h3 class="wp-block-heading">Warum ist Refactoring wichtig?</h3>



<ul class="wp-block-list">
<li><strong>Verbesserung der Code-Lesbarkeit</strong>: Lesbarkeit ist entscheidend, um den Code effizient zu warten und zu erweitern. Durch das Refactoring können Entwickler den Code vereinfachen, Duplikate entfernen und konsistente Benennungen und Formatierungen verwenden, um die Lesbarkeit zu verbessern.</li>



<li><strong>Reduzierung der technischen Schulden</strong>: Technische Schulden entstehen, wenn man die Software in Eile entwickelt, ohne auf Qualitätsstandards zu achten. Sie führen oft zu schwer zu wartendem und unzuverlässigem Code. Es hilft, technische Schulden zu reduzieren und verhindert, dass sie sich im Laufe der Zeit anhäufen.</li>



<li><strong>Optimierung der Code-Wartbarkeit</strong>: Refactoring hilft dabei, den Code modular und gut strukturiert zu halten, was die Wartung und Fehlerbehebung erleichtern kann.</li>



<li><strong>Verbesserung der Code-Performance</strong>: Durch das Entfernen von unnötigem Code und die Optimierung von Algorithmen kann Refactoring dazu beitragen, die Performance der Software zu steigern.</li>



<li><strong>Erleichterung der Teamarbeit</strong>: Ein sauberer und gut strukturierter Code ist leichter zu verstehen und ermöglicht eine effektivere Zusammenarbeit zwischen Entwicklern.</li>
</ul>



<h3 class="wp-block-heading">Strategien für effektives Refactoring</h3>



<ul class="wp-block-list">
<li><strong>Code Smells identifizieren</strong>: &#8222;Code Smells&#8220; sind Anzeichen dafür, dass man den Code möglicherweise verbessern muss. Beispiele sind lange Methoden, große Klassen, doppelter Code und unklare Benennungen. Entwickler sollten diese Anzeichen erkennen und entsprechende Maßnahmen ergreifen, um den Code zu verbessern.</li>



<li><strong>Schrittweise Verbesserungen vornehmen</strong>: Refactoring sollte schrittweise erfolgen, um den Code schrittweise zu verbessern und gleichzeitig die Funktionalität intakt zu halten.</li>



<li><strong>Automatisierte Tests verwenden</strong>: Um sicherzustellen, dass die Funktionalität nach dem Refactoring unverändert bleibt, ist es entscheidend, automatisierte Tests zu verwenden. Dies stellt sicher, dass Änderungen am Code keine unerwünschten Nebenwirkungen verursachen.</li>



<li><strong>Konsistente Coding-Standards einhalten</strong>: Ein konsistenter Codierungsstil erleichtert das Lesen und Verstehen des Codes. Es ist wichtig, dass das gesamte Team die gleichen Standards einhält, um Inkonsistenzen zu vermeiden.</li>



<li><strong>Regelmäßiges Refactoring betreiben</strong>: Man Refactoring als fortlaufenden Prozess betrachten, der in die tägliche Arbeit eines Entwicklers integriert ist. Regelmäßiges Refactoring hilft dabei, den Code kontinuierlich sauber und auf dem neuesten Stand zu halten, wodurch man die langfristige Wartbarkeit der Software verbessern kann. Außerdem hilft es dabei, den Code zu besser verstehen und tiefere Erkenntnisse über das Programmieren selbst zu erhalten.</li>
</ul>



<h3 class="wp-block-heading">Beliebte Refactoring-Techniken</h3>



<ol class="wp-block-list" type="1">
<li><strong>Extract Method</strong>: Wenn eine Methode zu lang oder zu komplex ist, kann sie in kleinere, gut definierte Methoden aufgeteilt werden, um die Lesbarkeit und Wartbarkeit des Codes zu verbessern.</li>



<li><strong>Rename Variable/Method/Class</strong>: Durch das Umbenennen von Variablen, Methoden und Klassen in klarere und aussagekräftigere Namen kann man den Code verständlicher und leichter pflegbar machen.</li>



<li><strong>Remove Duplication</strong>: Duplikate im Code können Wartungsprobleme verursachen und man sollte sie entfernen. Bei der Erkennung von Duplikaten können Entwickler allgemeine Funktionen extrahieren und wiederverwenden, um den Code zu straffen.</li>



<li><strong>Replace Conditional with Polymorphism</strong>: Anstatt mehrere bedingte Anweisungen zu verwenden, kann man Polymorphismus eingesetzen, um den Code besser zu strukturieren und die Lesbarkeit zu erhöhen.</li>



<li><strong>Encapsulate Field</strong>: Durch das Kapseln von Feldern in Klassen und die Bereitstellung von Zugriffs- und Mutationsmethoden kann man den Code modularer und besser wartbar machen.</li>
</ol>



<h3 class="wp-block-heading">Tools und Programme</h3>



<p>Es gibt eine Vielzahl von Tools und Programmen, die Entwicklern beim Refactoring helfen. Nachfolgend sind einige der gängigsten Tools für verschiedene Programmiersprachen (Einige davon habe ich bereits in diversen Beiträgen thematisiert. Hierzu einfach auf die jeweiligen Verlinkungen klicken oder die Suchfunktion verwenden 😉 ):</p>



<p>Integrated Development Environments (IDEs): Viele moderne IDEs bieten integrierte Refactoring-Unterstützung für verschiedene Programmiersprachen an. Einige der bekanntesten sind:</p>



<p>a. <a href="https://ceosbay.com/2023/03/10/erklaerung-intellij-idea/" target="_blank" rel="noreferrer noopener">JetBrains IntelliJ IDEA</a> (<a href="https://ceosbay.com/2023/03/16/erklaerung-java/" target="_blank" rel="noreferrer noopener">Java</a>, Kotlin, Scala, u.a.)</p>



<p>b. JetBrains PhpStorm (PHP)</p>



<p>c. JetBrains PyCharm (<a href="https://ceosbay.com/2022/12/20/erklaerung-python/" target="_blank" rel="noreferrer noopener">Python</a>)</p>



<p>d. JetBrains ReSharper (C# in Visual Studio)</p>



<p>e. Microsoft Visual Studio (C#, C++, VB.NET)</p>



<p>f. <a href="https://ceosbay.com/2023/03/19/erklaerung-eclipse/" target="_blank" rel="noreferrer noopener">Eclipse</a> (<a href="https://ceosbay.com/2023/03/16/erklaerung-java/" target="_blank" rel="noreferrer noopener">Java</a>)</p>



<p>g. Xcode (Swift, Objective-C)</p>



<p>Standalone-Tools: Es gibt auch eigenständige Refactoring-Tools, die man unabhängig von der IDE verwenden kann. Einige Beispiele sind:</p>



<p>a. JDeodorant (<a href="https://ceosbay.com/2023/03/16/erklaerung-java/" target="_blank" rel="noreferrer noopener">Java</a>)</p>



<p>b. SonarLint und SonarQube (<a href="https://ceosbay.com/2023/03/16/erklaerung-java/" target="_blank" rel="noreferrer noopener">Java</a>, <a href="https://ceosbay.com/2022/11/12/javascript/" target="_blank" rel="noreferrer noopener">JavaScript</a>, TypeScript, u.a.)</p>



<p>c. JSLint und ESLint (<a href="https://ceosbay.com/2022/11/12/javascript/" target="_blank" rel="noreferrer noopener">JavaScript</a>)</p>



<p>d. RuboCop (<a href="https://ceosbay.com/2022/12/19/erklaerung-ruby/" target="_blank" rel="noreferrer noopener">Ruby</a>)</p>



<p>e. Clang-Tidy (C++, Objective-C)</p>



<p>Code-Editor-Erweiterungen: Viele Code-Editoren, wie Visual Studio Code und Sublime Text, verfügen über Erweiterungen, die Refactoring-Unterstützung für verschiedene Programmiersprachen bieten. Einige dieser Erweiterungen sind:</p>



<p>a. Visual Studio Code Refactoring Extensions (z.B. <a href="https://ceosbay.com/2022/12/20/erklaerung-python/" target="_blank" rel="noreferrer noopener">Python</a>, <a href="https://ceosbay.com/2022/11/12/javascript/" target="_blank" rel="noreferrer noopener">JavaScript</a>, TypeScript, PHP, <a href="https://ceosbay.com/2022/12/19/erklaerung-ruby/" target="_blank" rel="noreferrer noopener">Ruby</a>, C#)</p>



<p>b. Sublime Text Refactoring Plugins (z.B. Anaconda für <a href="https://ceosbay.com/2022/12/20/erklaerung-python/" target="_blank" rel="noreferrer noopener">Python</a>, JsPrettier für <a href="https://ceosbay.com/2022/11/12/javascript/" target="_blank" rel="noreferrer noopener">JavaScript</a>)</p>



<p>Es ist wichtig zu beachten, dass jedes Tool seine eigenen Stärken und Schwächen hat. Ein Entwickler sollte die verfügbaren Optionen für seine Programmiersprache und seinen Arbeitsablauf sorgfältig prüfen, um das am besten geeignete Refactoring-Tool zu finden.</p>



<h3 class="wp-block-heading">Fazit</h3>



<p>Refactoring ist ein wesentlicher Bestandteil des Softwareentwicklungsprozesses, der es ermöglicht, den Code sauber, lesbar und wartbar zu halten. Durch das Identifizieren von &#8222;Code Smells&#8220;, die Anwendung bewährter Techniken und das kontinuierliche Integrieren von Refactoring in den Arbeitsablauf können Entwickler qualitativ hochwertigen Code schreiben, der leicht zu verstehen und zu erweitern ist.</p>



<p>Die Investition in regelmäßiges Refactoring zahlt sich langfristig aus, indem sie dazu beiträgt, die technischen Schulden zu reduzieren und die Zusammenarbeit im Team zu verbessern. Der Schlüssel zum erfolgreichen Refactoring liegt in der Kombination aus automatisierten Tests, konsistenten Codierungsstandards und einem proaktiven Ansatz zur Code-Optimierung. Durch die Priorisierung von Refactoring in der Softwareentwicklung können Entwickler sicherstellen, dass ihre Projekte skalierbar und zukunftssicher sind.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/04/10/erklaerung-refactoring/">Refactoring &#8211; Optimierung und Evolution für nachhaltigen Code</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2023/04/10/erklaerung-refactoring/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">1357</post-id>	</item>
		<item>
		<title>Angular &#8211; Entfaltung des vollen Potenzials von Webanwendungen</title>
		<link>https://ceosbay.com/2023/03/21/erklaerung-angular/</link>
					<comments>https://ceosbay.com/2023/03/21/erklaerung-angular/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Tue, 21 Mar 2023 18:57:09 +0000</pubDate>
				<category><![CDATA[Agile]]></category>
		<category><![CDATA[Cloud]]></category>
		<category><![CDATA[Datenbanken]]></category>
		<category><![CDATA[DevOps]]></category>
		<category><![CDATA[Entwicklung]]></category>
		<category><![CDATA[Internet]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programmieren]]></category>
		<category><![CDATA[Testing]]></category>
		<category><![CDATA[Website]]></category>
		<category><![CDATA[Angular]]></category>
		<category><![CDATA[AngularJS]]></category>
		<category><![CDATA[API]]></category>
		<category><![CDATA[App]]></category>
		<category><![CDATA[Architektur]]></category>
		<category><![CDATA[Databinding]]></category>
		<category><![CDATA[Dynamisch]]></category>
		<category><![CDATA[Eager]]></category>
		<category><![CDATA[ECMAScript]]></category>
		<category><![CDATA[Engine]]></category>
		<category><![CDATA[ES6]]></category>
		<category><![CDATA[First]]></category>
		<category><![CDATA[Framework]]></category>
		<category><![CDATA[Frequenz]]></category>
		<category><![CDATA[JS]]></category>
		<category><![CDATA[Komplexität]]></category>
		<category><![CDATA[Lade]]></category>
		<category><![CDATA[Ladetechnik]]></category>
		<category><![CDATA[Ladetechniken]]></category>
		<category><![CDATA[LTS]]></category>
		<category><![CDATA[Major]]></category>
		<category><![CDATA[mobile]]></category>
		<category><![CDATA[MVVM]]></category>
		<category><![CDATA[Optimization]]></category>
		<category><![CDATA[Patch]]></category>
		<category><![CDATA[Preloading]]></category>
		<category><![CDATA[Releae]]></category>
		<category><![CDATA[Rest]]></category>
		<category><![CDATA[scopes]]></category>
		<category><![CDATA[Script]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[Statisch]]></category>
		<category><![CDATA[TypeScript]]></category>
		<category><![CDATA[Web]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=1210</guid>

					<description><![CDATA[<p>AngularJS, als Vorgängerversion von Angular, ist ein JavaScript Framework für Web- und Softwareentwicklung, entwickelt von Goole. Anfangs für die Entwicklung von Single-Page-Apps gedacht und im Nachgang millionenfach für die Web-Anwendungsentwicklung genutzt. Google entwickelte damit das &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/03/21/erklaerung-angular/">Angular &#8211; Entfaltung des vollen Potenzials von Webanwendungen</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p>AngularJS, als Vorgängerversion von Angular, ist ein <a href="https://ceosbay.com/2022/11/12/javascript/" target="_blank" rel="noreferrer noopener">JavaScript</a> <a href="https://ceosbay.com/2022/11/14/erklaerung-frameworks/" target="_blank" rel="noreferrer noopener">Framework</a> für Web- und Softwareentwicklung, entwickelt von Goole. Anfangs für die Entwicklung von Single-Page-Apps gedacht und im Nachgang millionenfach für die Web-Anwendungsentwicklung genutzt. Google entwickelte damit das erste geeignete <a href="https://ceosbay.com/2022/11/14/erklaerung-frameworks/" target="_blank" rel="noreferrer noopener">Framework</a> für große Enterprise-Anwendungen. Durch Methoden wie Dependency Injection (Ein Entwurfsmuster, bei dem ein Objekt oder eine Funktion andere Objekte oder Funktionen empfängt, von denen es/sie abhängt) und ein ausgereiftes Tooling, ermöglichen eine effiziente und wartbare Softwareentwicklung auf Basis von <a href="https://ceosbay.com/2022/11/12/javascript/" target="_blank" rel="noreferrer noopener">JavaScript</a>.</p>



<p>Seit 2009 ist es ein <a href="https://ceosbay.com/2022/11/16/erklaerung-open-source/" target="_blank" rel="noreferrer noopener">Open-Source</a>-Projekt, dass auf gute Testbarkeit ausgelegt ist (An dieser Stelle möchte ich auf den <a href="https://ceosbay.com/2023/03/13/erklaerung-test-driven-development/" target="_blank" rel="noreferrer noopener">Test Driven Development</a> Beitrag verweisen 😉 ). Dies bietet ein MVC/MVVM-<a href="https://ceosbay.com/2022/11/14/erklaerung-frameworks/" target="_blank" rel="noreferrer noopener">Framework</a>, welches bidirektionales Databinding unterstützt.</p>



<h3 class="wp-block-heading">MVC/MVVM?</h3>



<p>MVVM teilt die verschiedenen Komponenten des Entwicklungsprozesses in drei Kategorien auf. Model, View und ViewModel. In der Regel handelt es sich dabei um Code-Markup oder grafische Benutzeroberflächen (GUI). MVC (Model-View-Control) ist eine Methode, mit der Entwickler Programme in diese drei Komponenten aufteilen. Auf diese Weise lassen sich geschäftliche Anforderungen und Regeln von der Art und Weise unterscheiden, wie Benutzer mit der Anwendung arbeiten. Gerne gehe ich in einem zukünftigen Beitrag näher darauf ein.</p>



<h3 class="wp-block-heading">Unterschiede zwischen Angular und AngularJS</h3>



<p>Angular ist wie bereits erwähnt der Nachfolger von AngularJS. Von Grund auf neu geschrieben, unterscheiden die beiden sich grundsätzlich und in vielerlei Hinsicht.</p>



<ul class="wp-block-list">
<li>Angular kennt keine „scopes“ oder Controller, sondern verwendet eine Hierarchie von Komponenten als zentrales Architekturkonzept.</li>



<li>Angular hat eine einfachere Syntax für Ausdrücke: Mit „[ ]“ werden Bindings für Eigenschaften und mit „( )“ werden Bindings für Events erzeugt.</li>



<li>Mobile-First-Ansatz: Die Anforderungen von mobilen Plattformen haben besondere Priorität.</li>



<li>Modularität: Module können Funktionalitäten auslagern, sodass Code leichtgewichtiger und schneller sein kann.</li>



<li>Es liegt lediglich die Unterstützung moderner Browser vor, wodurch man weniger Workarounds wegen Browser-Kompatibilitätsproblemen benötigt.</li>



<li>Angular empfiehlt die Verwendung von TypeScript. Es bietet Klassenbasierte objektorientierte Programmierung, Statische Typisierung und Generics.</li>



<li>TypeScript ist eine Obermenge von ECMAScript 6 (ES6) und ist rückwärts kompatibel mit ECMAScript 5, damit JavaScript. Angular bietet somit auch die Vorzüge von ES6: (Lambdas, Iteratoren, for…of-Schleifen, Generatoren im Stil von <a href="https://ceosbay.com/2022/12/20/erklaerung-python/" target="_blank" rel="noreferrer noopener">Python</a>, Reflexion)</li>



<li>Verbesserte Dependency Injection: Bindings ermöglichen die Benennung von Abhängigkeiten.</li>



<li>Directives dienen dem Zweck, dass Aussehen und Verhalten eines Tags dynamisch zu verändern.</li>



<li>Dynamisches Laden ist möglich</li>



<li>Asynchrone Kompilierung von Templates</li>



<li>Einfacheres Routing</li>



<li>Kontroller und $scope sind durch Komponenten und Directives ersetzt. Eine Komponente ist eine Directive mit einem Template.</li>



<li>Reaktive Programmierung mit RxJS</li>
</ul>



<h3 class="wp-block-heading">Angular für konventionelle Websites?</h3>



<p>Angular ist ideal für Websites mit dynamischem Inhalt, jedoch nicht für kleine Seiten mit statischem Inhalt geeignet. Die Implementierung von Angular erhöht in diesem Fall lediglich die Gesamtgröße des Projekts und folglich auch die Ladezeiten. Dies ist eines der Hauptgründe, warum man Angular nicht für Landing Pages und Websites mit statischem Inhalt verwenden sollte. Davon abgesehen ist Angular weit davon entfernt, <a href="https://ceosbay.com/2022/11/23/erklaerung-seo/" target="_blank" rel="noreferrer noopener">SEO</a>-freundlich zu sein. Und im Zeitalter von <a href="https://ceosbay.com/2022/11/23/erklaerung-seo/" target="_blank" rel="noreferrer noopener">Search-Engine-Optimization</a> gibt es weitaus bessere Alternativen, um dieses Ziel zu erreichen. Auch ist Angular keine gute Lösung für kurzfristige Projekte oder Start-ups mit begrenzten Ressourcen. Die Komplexität des Front-Ends kann in relativ kurzer Zeit immense Ausmaße annehmen und später schwer zu bändigen sein.</p>



<p>Das Hauptanwendungsgebiet von Angular bestand darin, Einzelseiten-Webanwendungen zu erstellen. Aus diesem Grund verfügt es über eine breite Palette von Werkzeugen für die SPA-Entwicklung. Darüber hinaus ist es eine ideale Technologie für Websites, bei denen sich der Inhalt auf der Grundlage des Nutzerverhaltens und der Präferenzen der Benutzer dynamisch anpasst. Dependency Injections stellen sicher, dass im Falle der Änderung einer Komponente andere Komponenten, die mit ihr in Zusammenhang stehen, automatisch mitgeändert werden.</p>



<h3 class="wp-block-heading">Die 3 verschiedenen Ladetechniken</h3>



<p>Bei der Arbeit mit Angular bieten sich 3 verschiedene Ladetechniken an. Diese sind das Eager Loading, Lazy Loading und Preloading, auf die ich nachfolgend eingehe.</p>



<p><strong>Eager Loading (Eifriges Laden)</strong></p>



<p>Der Abruf aller benötigten Daten möglichst wirksam und umgehend bzw. sofort. Hierzu gibt es im Grunde genommen nicht viel anzumerken. Die Technik ist zwar effizient, doch die Tatsache, dass man eventuell nur einen bestimmten Teil der Daten benötigt aber dennoch alle Daten lädt, kann sich schnell zu einem Nachteil entwickeln, wenn es sich um große Datenmengen handelt.</p>



<p><strong>Lazy Loading (Langsames Laden)</strong></p>



<p>Die am wenigsten eifrige bzw. nicht eifrige Ladetechnik. Wenn man faul ist, tut man so lange nichts, bis man es wirklich muss oder dazu gezwungen wird. Man stelle sich vor, dass die Anwendung drei Bereiche hat. Home, Admin und das Dashboard. Auf den Home-Bereich wird ständig zugegriffen, auf den Dashboard-Bereich die meiste Zeit. Der Admin-Bereich wird jedoch nur von einigen wenigen Nutzern verwendet. Folglich kann man die Admin-Route nach und nach laden. So lange niemand auf die Idee kommt, auf den Verwaltungsbereich der Anwendung zu klicken, wird der damit verbundene Code auch nicht ausgeführt bzw. nicht geladen.</p>



<p>Die Mehrheit der Nutzer lädt den Code für den Verwaltungsbereich schlichtweg nie. Wenn man also Lazy Loading verwendet, kann man grundsätzlich schneller auf die Anwendung zugreifen, da man nicht so viel Code vom Server laden muss. Dies hängt damit zusammen, dass das ORM-Werkzeug (Objekt-Relationales Mapping-Werkzeug) jeglichen Zugriff auf alle Objektreferenzen »abfangen« muss, um hier bei Bedarf die verbundenen Objekte nachladen zu können. Dieses Abfangen erfolgt durch die Verwendung bestimmter Klassen für Einzelreferenzen und Mengenklassen. Der Unterschied zwischen den ORM-Werkzeugen liegt darin, ob der Entwickler diese Klassen explizit im Code verwenden muss oder ob das ORM-Werkzeug diese beim Kompilieren oder zur Laufzeit austauscht.</p>



<p><strong>Preloading (Vorladen)</strong></p>



<p>Die „somewhere-in-between“ (Irgendwie Zwischendrin) Ladetechnik. Beim Preloading macht man im Grunde genommen dasselbe wie beim Lazy Loading, nur ein bisschen anders.</p>



<p>Anhand des Home, Dashboard und Admin Beispiels lässt sich dies folgendermaßen darstellen. Die Startseite braucht man immer. Also lädt man diese schnell bzw. eifrig. Der Admin-Bereich wird nur selten und nur von wenigen Benutzern benötigt, also kann man diesen erst einmal etwas vernachlässigen bzw. &#8222;lazy&#8220; laden. Aber das Dashboard ist nicht das Erste, was ein Benutzer sieht, also kann es grundsätzlich erst einmal warten. Doch das Dashboard ist gleichzeitig etwas, dass die meisten der Benutzer irgendwann sehen möchten. Also sollte es zumindest dann zur Verfügung stehen, wenn das Laden des Home-Bereichs fertiggestellt ist. Nach jeder erfolgreichen Navigation sucht der Router in seiner Konfiguration nach einem nicht geladenen Modul, das er vorladen kann.</p>



<p>Der Home-Bereich wird erfolgreich geladen und unmittelbar danach wird der Dashboard-Bereich im Hintergrund geladen.</p>



<h3 class="wp-block-heading">Welche Ladetechnik kann/soll ich nun verwenden?</h3>



<p>Wie bei vielen Angelegenheiten in der IT kommt es hier auf den spezifischen Anwendungsfall und den zur Verfügung stehenden Ressourcen an. Wenn man nicht genau weiß, ob man die zusätzlichen Daten benötigt oder nicht, dann kann es ungünstig sein, sie direkt zu laden. Es kann aber auch ungünstig sein, sie später nachladen zu müssen. Entscheidend bei der Entscheidung ist die Wahrscheinlichkeit, ob und wann man die jeweiligen Daten für wen benötigt, um welche Datenmenge es sich handelt und ob man die Daten später einfach nachladen kann. Zu beachten ist, dass man ein automatisches Nachladen, nach einer Serialisierung, in der Regel nicht mehr initiieren kann.</p>



<h3 class="wp-block-heading">Release-Frequenz</h3>



<p>Angular Releases folgen dem Konzept des Semantic Versionings. Man unterscheidet zwischen Major-, Minor- und Bugfix-Releases. Alle 6 Monate gibt es eine neue Major Release. Major Releases enthalten signifikante neue Features, sind aber nicht abwärtskompatibel. Der Umstieg auf eine neuere Major Release benötigt daher oft Update-Scripts, Refactorings des bestehenden Codes, weitere Tests und das Erlernen neuer APIs. Zu jeder Major Release gibt es ein bis drei Minor Releases. Patch Releases und Pre-Releases gibt es fast jede Woche.</p>



<h3 class="wp-block-heading">Support</h3>



<p>Der Support von Major Releases beträgt typischerweise 18 Monate lang nach Release. Davon 6 Monate aktiv. Aus diesem Grund gibt es in regelmäßigen Abständen Minor Releases und Patch Releases. Es folgt ein 12-monatiger Long Term Support (LTS) in Form von Patch-Releases, ausschließlich zur Behebung kritischer und sicherheitsrelevanter Fehler.</p>



<h3 class="wp-block-heading">Fazit</h3>



<p>Bei der Verwendung von Angular sollte von vornherein klar sein, dass die Realisierung eines Projekts mit der Abnahme vieler Entscheidungen über Architektur und des Renderings verbunden ist. Dies hat den Vorteil, dass sich das Projektteam zu 100% auf die Umsetzung von Features konzentrieren kann und nicht die grundlegende Architektur eigenständig aufbauen muss.</p>



<p>Durch die sehr einheitliche Struktur von Angular Anwendungen lassen sich gute Entwickler sehr schnell in das Projekt integrieren, da Angular Anwendungen stets einer gewissen Struktur folgen. Dies vereinfacht die Skalierbarkeit des Teams als auch des Projektes selbst als vergleichsweise bei Individuallösungen der Architektur in anderen <a href="https://ceosbay.com/2022/11/14/erklaerung-frameworks/" target="_blank" rel="noreferrer noopener">Frameworks</a>.</p>



<p>Generell ist es für Enterprise Projekte sicherlich eine gute Wahl. Dennoch sollte man andere <a href="https://ceosbay.com/2022/11/14/erklaerung-frameworks/" target="_blank" rel="noreferrer noopener">Frameworks</a> wie <a href="https://ceosbay.com/2022/12/21/erklaerung-react/" target="_blank" rel="noreferrer noopener">React</a> und VueJS nicht außer Acht lassen, über die ich in den kommenden Tagen schreibe.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/03/21/erklaerung-angular/">Angular &#8211; Entfaltung des vollen Potenzials von Webanwendungen</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2023/03/21/erklaerung-angular/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">1210</post-id>	</item>
		<item>
		<title>SonarQube &#8211; Das Code-Qualitätsmanagement-Tool</title>
		<link>https://ceosbay.com/2023/03/17/erklaerung-sonarqube/</link>
					<comments>https://ceosbay.com/2023/03/17/erklaerung-sonarqube/#respond</comments>
		
		<dc:creator><![CDATA[CEO]]></dc:creator>
		<pubDate>Fri, 17 Mar 2023 16:12:48 +0000</pubDate>
				<category><![CDATA[Agile]]></category>
		<category><![CDATA[Entwicklung]]></category>
		<category><![CDATA[Internet]]></category>
		<category><![CDATA[Programmieren]]></category>
		<category><![CDATA[Sicherheit]]></category>
		<category><![CDATA[Testing]]></category>
		<category><![CDATA[Website]]></category>
		<category><![CDATA[1061]]></category>
		<category><![CDATA[1998]]></category>
		<category><![CDATA[Analyse]]></category>
		<category><![CDATA[Anwendung]]></category>
		<category><![CDATA[API]]></category>
		<category><![CDATA[c#]]></category>
		<category><![CDATA[Checkstyle]]></category>
		<category><![CDATA[Cobol]]></category>
		<category><![CDATA[Code]]></category>
		<category><![CDATA[Codebasis]]></category>
		<category><![CDATA[Entwicklungsprozess]]></category>
		<category><![CDATA[Fazit]]></category>
		<category><![CDATA[FindBugs]]></category>
		<category><![CDATA[Flex]]></category>
		<category><![CDATA[Framework]]></category>
		<category><![CDATA[Frameworks]]></category>
		<category><![CDATA[Governance]]></category>
		<category><![CDATA[Groovy]]></category>
		<category><![CDATA[GUI]]></category>
		<category><![CDATA[IEEE]]></category>
		<category><![CDATA[Java]]></category>
		<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[Komplexität]]></category>
		<category><![CDATA[PC]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[Plugin]]></category>
		<category><![CDATA[PMD]]></category>
		<category><![CDATA[Prüfung]]></category>
		<category><![CDATA[Qube]]></category>
		<category><![CDATA[Quellcode]]></category>
		<category><![CDATA[Quelle]]></category>
		<category><![CDATA[Quelltext]]></category>
		<category><![CDATA[Rechner]]></category>
		<category><![CDATA[Richtlinien]]></category>
		<category><![CDATA[Schnittstellen]]></category>
		<category><![CDATA[Schulden]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[Sonar]]></category>
		<category><![CDATA[SonarQube]]></category>
		<category><![CDATA[Sprache]]></category>
		<category><![CDATA[SQL]]></category>
		<category><![CDATA[Standard]]></category>
		<category><![CDATA[Sting]]></category>
		<category><![CDATA[Test]]></category>
		<category><![CDATA[Überprüfen]]></category>
		<category><![CDATA[Zyklomatisch]]></category>
		<guid isPermaLink="false">https://ceosbay.com/?p=1176</guid>

					<description><![CDATA[<p>SonarQube früher Sonar, ist eine Plattform für die statische Analyse und Bewertung der technischen Qualität von Quelltext bzw. Code. SonarQube analysiert den Quelltext hinsichtlich verschiedener Qualitätsmerkmale und stellt die Ergebnisse über eine Website dar. SonarQube &#8230;</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/03/17/erklaerung-sonarqube/">SonarQube &#8211; Das Code-Qualitätsmanagement-Tool</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></description>
										<content:encoded><![CDATA[
<p>SonarQube früher Sonar, ist eine Plattform für die statische Analyse und Bewertung der technischen Qualität von Quelltext bzw. Code. SonarQube analysiert den Quelltext hinsichtlich verschiedener Qualitätsmerkmale und stellt die Ergebnisse über eine Website dar. SonarQube ist in <a href="https://ceosbay.com/2023/03/16/erklaerung-java/" target="_blank" rel="noreferrer noopener">Java</a> programmiert, unterstützt aber neben der Analyse von <a href="https://ceosbay.com/2023/03/16/erklaerung-java/" target="_blank" rel="noreferrer noopener">Java</a>-Anwendungen mit entsprechenden Plugins unter anderem die Programmiersprachen <a href="https://ceosbay.com/2022/11/12/javascript/" target="_blank" rel="noreferrer noopener">JavaScript</a>, Groovy, Flex, PHP, PL/SQL, C#, Cobol und die des .Net-Frameworks.</p>



<h3 class="wp-block-heading">Wie funktioniert SonarQube?</h3>



<p><strong>SonarQube besteht aus drei Komponenten</strong></p>



<ol class="wp-block-list" type="1">
<li>Einem Modul für Build-Management-Tools wie <a href="https://ceosbay.com/2022/12/22/erklaerung-maven/" target="_blank" rel="noreferrer noopener">Apache Maven</a> oder Apache Ant. (Hauptsächlich für die Analyse des Quelltextes hinsichtlich verschiedener Qualitätsmerkmale.)</li>



<li>Einer Datenbank, für Speicherung der Ergebnisse der Qualitätsanalyse.</li>



<li>Einer Website für die visuelle Darstellung, Auswertung und das Management der Qualitätsanalyse-Ergebnisse.</li>
</ol>



<p>Durch diese Architektur kann man sowohl eine Prüfung des Quelltextes auf dem Entwicklungsrechner ermöglichen als auch eine Einbindung von SonarQube in den Entwicklungsprozess gewährleisten. Dies unterstützt die Ermittlung der Qualitätsmetriken auf einem Build-Server für die kontinuierliche Integration.</p>



<p>SonarQube analysiert den Quelltext hinsichtlich der Abdeckung durch Modultests, checkt den Quellcode nach doppeltem Code und in Bezug auf die Komplexität. Auch werden unter anderem potenzielle Fehler im Code, Kodier-Richtlinien als auch Kommentare überprüft.</p>



<h3 class="wp-block-heading">Modularer Aufbau und Erweiterungen</h3>



<p>SonarQube ist modular aufgebaut und integriert selbst einige bekannte Entwicklungswerkzeuge zur Analyse der Codequalität, darunter PMD und Checkstyle für die Erkennung von doppeltem Code für die Prüfung von Kodier-Richtlinien. Damit wird unter anderem auch nach ineffizientem Code gesuche. FindBugs dient beispielsweise zum Aufdecken potenzieller Fehler sowie Surefire und Cobertura zur Messung der Qualität der Modultests.</p>



<p>Diese Werkzeuge nutzen entsprechend ihrer Natur und Einsatzgebiete Metriken, um die jeweiligen Auswertungen bzw. Statistiken zu erzeugen. Der Name „Metrik“ trägt jedoch wenig Bedeutung von dem in sich, was eine Metrik ausmacht. Schlägt man nämlich nach woher der Name kommt, landet man im Lateinischen: „ars metrica„, die Lehre von den Maßen. Fragt man jedoch das Institute of Electrical and Electronics Engineers, was eine Softwaremetrik ist, erhält man folgende Antwort:</p>



<p>„software quality metric: A function whose inputs are software data and whose output is a single numerical value that can be interpreted as the degree to which software possesses a given attribute that affects its quality.“ „Eine Softwarequalitätsmetrik ist eine Funktion, die eine Software-Einheit in einen Zahlenwert abbildet, der als Erfüllungsgrad einer Qualitätseigenschaft der Software-Einheit interpretierbar ist.“ – IEEE Standard 1061, 1998</p>



<p>Folglich bedeutet dies, dass es sich bei einer Metrik am Ende des Tages um eine Funktion handelt, die für beliebige Eingaben Zahlen erzeugt. Die Beschaffenheit ist so, dass sie, nur so&nbsp;</p>



<p>lange sie von derselben Funktion erzeugt wurden, vergleichbar sind. Dadurch kann man Rückschlüsse auf die Eingabe mit Hinblick auf die Funktion erzielen.</p>



<p>Ein Beispiel dafür ist die McCabe-Metrik, auch zyklomatische Komplexität genannt. Diese sehr grundlegende Metrik berechnet die Anzahl der unterschiedlichen Pfade durch ein Stück Code. Die Formel ist relativ einfach: Es wird die Anzahl an Kontrollstrukturen wie if, while, case und boolescher Operatoren wie &amp;&amp; und || summiert und nochmals mit 1 addiert. Möchte man diese Information nochmals anhand eines Beispiels betrachten, sieht es folgendermaßen aus:</p>



<pre class="wp-block-code"><code>String nameDesWochenTags(int nr) {
  switch(nr) {
    case 1: return "Montag";
    case 2: return "Dienstag";
    case 3: return "Mittwoch";
    case 4: return "Donnerstag";
    case 5: return "Freitag";
    case 6: return "Samstag";
    case 7: return "Sonntag";
  }
  return "";
}</code></pre>



<p>Diese relativ einfache Methode gibt den Namen eines Wochentages entsprechend seiner 1-indizierten Position innerhalb der Woche zurück. Ihre zyklomatische Komplexität beträgt 8. Zumal 1 + 7 x case. Dies ist ein verhältnismäßig hoher Wert. Ein Maximalwert von 10 gilt als allgemein akzeptiert und ausreichend erprobt. Um also die Komplexität dieser Methode zu verringern, findet eine Refaktorisierung statt, die folgendermaßen aussehen kann:</p>



<pre class="wp-block-code"><code>String nameDesWochenTags(int nr) {
  String&#91;] names = new String&#91;] {
    "Montag", "Dienstag", "Mittwoch",
    "Donnerstag", "Freitag", "Samstag",
    "Sonntag"
  };
  if(nr) &gt; 0 &amp;&amp; &lt;= names.length) {
    return names&#91;nr - 1];
  }
  return "";
}</code></pre>



<p>Die zyklomatische Komplexität dieser Methode beträgt 3. Zumal 1 + 1 x if + 1 x &amp;&amp;. Durch den unterschiedlichen Ansatz kann man die Komplexität verringern. Dennoch ist es relativ unstrittig, dass die erste Version leichter zu verstehen ist.</p>



<p>Will man nun also alle Tools gemeinsam benutzen, muss man alle konfigurieren und ihre Ergebnisse zusammenführen, damit sich ein Gesamtbild darstellen lässt. Außerdem kommt es dabei zwangsweise zu Dopplungen in ausgewerteten Metriken oder anderen Kennzahlen. PMD beispielsweise besitzt durch seinen relativ vagen Aufgabenbereich Überschneidungen im Hinblick auf Codestil mit checkstyle, während es aber auch genauso wie FindBugs auf toten Code achtet. An solchen und weiteren Stellen kann SonarQube Verbesserungen herbeiführen.</p>



<p>Neben der visuellen Anzeige der Ergebnisse der einzelnen Bereiche, ermöglicht SonarQube das Drill-Down der Ergebnisse bis auf die einzelne Metrik und Codezeile sowie die Verknüpfung der einzelnen Metriken sowie die Darstellung ihrer historischen Entwicklung in einer recht übersichtlichen grafischen Oberfläche.</p>



<p>Über einen ausgeklügelten Plugin-Mechanismus ist eine relativ einfache Integration von Erweiterungen möglich. Neben den Erweiterungen für die Analyse zusätzlicher Programmiersprachen gibt es Plugins für ergänzende Metriken, Governance, Schnittstellen zu Entwicklungsumgebungen, Visualisierungen, Integration sowie zur Berechnung der technischen Schuld(en).</p>



<h3 class="wp-block-heading">Fazit</h3>



<p>Ich arbeite noch nicht so lange mit SonarQube. Um genau zu sein, habe ich es mir erst heute das erste Mal angeschaut. Zusammenfassend kann ich folgendes sagen:</p>



<p>Statistiken sind zwar interessant und es kann Spaß machen, sich diese anzuschauen, doch ist eine statische Codeanalyse erst dann wirklich vollständig, wenn ein Mindestmaß an Interpretation hineingeflossen ist.</p>



<p>Die Codeanalyse liefert ein gutes Gefühl für die Codebasis. Erst so kann man fundierte Aussagen darüber treffen, welche Bereiche des Projekts besonders gefährdet, instabil oder verbesserungsfähig sind.</p>



<p>Regelmäßige Analysen können die Teammotivation erhöhen. Eine positive Issuebilanz am Ende eines Sprints und aufwärtszeigende Historiengraphen sollten gute Treiber für eine Gruppe Entwickler und ein Beweis für die eigene Leistung sein.</p>



<p>Alles in allem sind Analyseergebnisse immer gut als Argumentationsgrundlage. Mit Hilfe der Projekthistorie, die eine Auswahl gut darstellbarer Kennzahlen beinhaltet, kann man vor Kunden oder Entscheidern besser über ein eventuell nötiges technisches Release diskutieren.</p>
<p>Der Beitrag <a href="https://ceosbay.com/2023/03/17/erklaerung-sonarqube/">SonarQube &#8211; Das Code-Qualitätsmanagement-Tool</a> erschien zuerst auf <a href="https://ceosbay.com">CEOsBay</a>.</p>
]]></content:encoded>
					
					<wfw:commentRss>https://ceosbay.com/2023/03/17/erklaerung-sonarqube/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
		<post-id xmlns="com-wordpress:feed-additions:1">1176</post-id>	</item>
	</channel>
</rss>
