„Programmierung“ – Versionsunterschied
[gesichtete Version] | [gesichtete Version] |
Literatur eingefügt |
tk k |
||
Zeile 1: | Zeile 1: | ||
{{Dieser Artikel|behandelt die Tätigkeit der Erstellung von Software. Zu weiteren Bedeutungen siehe [[Programmierung (Begriffsklärung)]].}} |
{{Dieser Artikel|behandelt die Tätigkeit der Erstellung von Software. Zu weiteren Bedeutungen siehe [[Programmierung (Begriffsklärung)]].}} |
||
'''Programmierung''' (von |
'''Programmierung''' (von {{grcS|πρόγραμμα|prógramma}} „öffentlich und schriftlich bekannt gemachte Nachricht, Befehl“)<ref>[[Wilhelm Pape]], Max Sengebusch (Bearb.): ''Handwörterbuch der griechischen Sprache''. 3. Auflage, 6. Abdruck, Vieweg & Sohn, Braunschweig 1914; [http://images.zeno.org/Pape-1880/K/big/Pape-1880----02-0714.png zeno.org]</ref> bezeichnet die Tätigkeit, [[Computerprogramm]]e zu erstellen und wird der [[Softwaretechnik|Softwareentwicklung]] zugerechnet.<ref>[https://www.ibm.com/de-de/topics/software-development ''Was ist Softwareentwicklung?''] IBM; abgerufen am 18. Juni 2024</ref> |
||
Computerprogramme werden mit Hilfe einer [[Programmiersprache]] formuliert („codiert“). |
Computerprogramme werden mit Hilfe einer [[Programmiersprache]] formuliert („codiert“). Die [[Softwareentwickler#Rollen und Aufgaben|Programmierenden]] überführen dabei die z. B. im [[Pflichtenheft]] vorgegebenen [[Anforderung (Informatik)|Anforderungen]] in eine bestimmte Programmiersprache. Teilweise werden dazu [[Codegenerator]]en verwendet, die Teile des Programmcodes auf Basis von [[Modell]]en (die im Entwurf entstanden sind) automatisch erzeugen. |
||
Beim Programmieren sind wesentliche Aspekte zur [[Softwarequalität]] zu berücksichtigen und durch die Gestaltung des [[Quelltext|Quellcodes]] umzusetzen. Siehe dazu als Beispiele: [[Programmierstil]], [[Benutzerfreundlichkeit]],<ref>{{Internetquelle |url=http://sebastiandoern.de/ |titel= |
Beim Programmieren sind wesentliche Aspekte zur [[Softwarequalität]] zu berücksichtigen und durch die Gestaltung des [[Quelltext|Quellcodes]] umzusetzen. Siehe dazu als Beispiele: [[Programmierstil]], [[Benutzerfreundlichkeit]],<ref>{{Internetquelle |autor=Sebastian Dörn |url=http://sebastiandoern.de/ |titel=Programmieren lernen und Algorithmen verstehen |abruf=2018-01-12}}</ref> [[Wiederverwendbarkeit]] / [[Modularität]], [[Wartbarkeit]]. |
||
„Programmieren“ ''in erweitertem Sinn'' umfasst neben der Codeerstellung zahlreiche weitere Tätigkeiten, zum Beispiel das Testen [[Softwaretest#Weitere Klassifikationen für Testarten|(Entwicklertest)]] des Programms oder das Erstellen der [[Softwaredokumentation#Programmiererdokumentation|Programmdokumentation]]. ''Abgrenzen'' vom Begriff des Programmierens lassen sich andere Tätigkeiten zur Softwareentwicklung wie beispielsweise das [[Projektmanagement]], die [[Anforderungsanalyse (Informatik)|Anforderungsanalyse]] oder die [[Datenmodellierung]]. |
„Programmieren“ ''in erweitertem Sinn'' umfasst neben der Codeerstellung zahlreiche weitere Tätigkeiten, zum Beispiel das Testen [[Softwaretest#Weitere Klassifikationen für Testarten|(Entwicklertest)]] des Programms oder das Erstellen der [[Softwaredokumentation#Programmiererdokumentation|Programmdokumentation]]. ''Abgrenzen'' vom Begriff des Programmierens lassen sich andere Tätigkeiten zur Softwareentwicklung wie beispielsweise das [[Projektmanagement]], die [[Anforderungsanalyse (Informatik)|Anforderungsanalyse]] oder die [[Datenmodellierung]]. |
||
Abhängig vom Typ und der Einsatzumgebung von Software (z. B. für [[Systemsoftware]], Spielesoftware, [[Standardsoftware]], Grafiksoftware. |
Abhängig vom Typ und der Einsatzumgebung von Software (z. B. für [[Systemsoftware]], Spielesoftware, [[Standardsoftware]], Grafiksoftware. usw.) können zur Entwicklung unterschiedliche Verfahren oder/und Werkzeuge (wie Programmiersprachen, Testverfahren etc.) zum Einsatz kommen und/oder von spezialisierten [[Softwareentwickler|Entwicklern]] ausgeführt werden. |
||
Je nach angewendetem [[Vorgehensmodell zur Softwareentwicklung|Vorgehensmodell]] verlaufen die Aktivitäten zur Programmierung in zeitlich voneinander abgegrenzten [[Projektphase]]n, parallel oder iterativ. In der Praxis geschieht das Programmieren häufig in Teamarbeit, mit modernen Entwicklungsmethoden (wie [[Agile Softwareentwicklung]]) und [[Programmierwerkzeug]]en. |
Je nach angewendetem [[Vorgehensmodell zur Softwareentwicklung|Vorgehensmodell]] verlaufen die Aktivitäten zur Programmierung in zeitlich voneinander abgegrenzten [[Projektphase]]n, parallel oder iterativ. In der Praxis geschieht das Programmieren häufig in Teamarbeit, mit modernen Entwicklungsmethoden (wie [[Agile Softwareentwicklung]]) und [[Programmierwerkzeug]]en. |
||
Zeile 18: | Zeile 18: | ||
{{Siehe auch|Computerprogramm#Geschichte|Geschichte der Programmiersprachen|Programmiersprache#Geschichte|titel1=Computerprogramm: Geschichte|titel3=Programmiersprache – Geschichte}} |
{{Siehe auch|Computerprogramm#Geschichte|Geschichte der Programmiersprachen|Programmiersprache#Geschichte|titel1=Computerprogramm: Geschichte|titel3=Programmiersprache – Geschichte}} |
||
[[Charles Babbage]] beschrieb 1834 eine programmierbare Maschine, die [[Analytical Engine]],<ref>http://www.computerhistory.org/babbage/engines/</ref> welche allerdings nie gebaut wurde. Seine „Notations of calculations for the Analytical Engine“ umfasst 27 Programme. Diese sind in „The Babbage Papers“ des Science Museums von London abrufbar.<ref>https://collection.sciencemuseumgroup.org.uk/documents/aa110000020</ref> Die Programme enthalten bereits „Indirekte Adressierung“ und „bedingte Ausführungen“ (IF-THEN-ELSE-Befehle). Diese Dokumente dürften als erste Programme und Programmiersprache bezeichnet werden. |
[[Charles Babbage]] beschrieb 1834 eine programmierbare Maschine, die [[Analytical Engine]],<ref>[http://www.computerhistory.org/babbage/engines/ computerhistory.org]</ref> welche allerdings nie gebaut wurde. Seine „Notations of calculations for the Analytical Engine“ umfasst 27 Programme. Diese sind in „The Babbage Papers“ des Science Museums von London abrufbar.<ref>[https://collection.sciencemuseumgroup.org.uk/documents/aa110000020 collection.sciencemuseumgroup.org.uk]</ref> Die Programme enthalten bereits „Indirekte Adressierung“ und „bedingte Ausführungen“ (IF-THEN-ELSE-Befehle). Diese Dokumente dürften als erste Programme und Programmiersprache bezeichnet werden. |
||
[[Ada Lovelace]] übersetzte 1843 eine ursprünglich französische Beschreibung der Analytical Engine von [[Luigi Federico Menabrea]] ins Englische und fügte eigene Notizen hinzu. Diese Anmerkungen enthielten einen tabellarischen Plan zur Berechnung der Bernoulli-Zahlen. 1941 realisierte [[Konrad Zuse]] mit dem [[Zuse Z3|Z3]] die erste programmgesteuerte Rechenmaschine, von 1942 an entwickelte er mit [[Plankalkül]] die erste [[höhere Programmiersprache]].<ref>https://link.springer.com/chapter/10.1007/978-3-642-18631-8_9</ref> Die Mathematikerin [[Grace Hopper]] schuf 1949 den ersten [[Compiler]], der Quellcode in Maschinencode übersetzt.<ref>[http://www.cs.yale.edu/homes/tap/Files/hopper-story.html Grace Hopper] |
[[Ada Lovelace]] übersetzte 1843 eine ursprünglich französische Beschreibung der Analytical Engine von [[Luigi Federico Menabrea]] ins Englische und fügte eigene Notizen hinzu. Diese Anmerkungen enthielten einen tabellarischen Plan zur Berechnung der Bernoulli-Zahlen. 1941 realisierte [[Konrad Zuse]] mit dem [[Zuse Z3|Z3]] die erste programmgesteuerte Rechenmaschine, von 1942 an entwickelte er mit [[Plankalkül]] die erste [[höhere Programmiersprache]].<ref>[https://link.springer.com/chapter/10.1007/978-3-642-18631-8_9 link.springer.com]</ref> Die Mathematikerin [[Grace Hopper]] schuf 1949 den ersten [[Compiler]], der Quellcode in Maschinencode übersetzt.<ref>[http://www.cs.yale.edu/homes/tap/Files/hopper-story.html Grace Hopper.] Yale University; abgerufen am 7. Juni 2016</ref> |
||
== Qualitätskriterien == |
== Qualitätskriterien == |
||
Zeile 41: | Zeile 41: | ||
Damit eine [[Software]] dauerhaft funktioniert, muss sie ''wartbar'' sein. Das heißt, Änderungen wie [[Bugfix]]es, Anpassungen und neue [[Feature-Request|Features]] müssen ohne großen Aufwand eingepflegt werden können. Dies erfordert vor allem, dass der Programmierer keinen zu kurzen, „kryptischen“ [[Quelltext]] (oder ''Quellcode'') erzeugen soll, der für andere Entwickler nicht oder nur mit hoher Einarbeitungszeit verständlich ist. |
Damit eine [[Software]] dauerhaft funktioniert, muss sie ''wartbar'' sein. Das heißt, Änderungen wie [[Bugfix]]es, Anpassungen und neue [[Feature-Request|Features]] müssen ohne großen Aufwand eingepflegt werden können. Dies erfordert vor allem, dass der Programmierer keinen zu kurzen, „kryptischen“ [[Quelltext]] (oder ''Quellcode'') erzeugen soll, der für andere Entwickler nicht oder nur mit hoher Einarbeitungszeit verständlich ist. |
||
Um solche Probleme zu vermeiden, existieren häufig [[Namenskonvention (Datenverarbeitung)|Namenskonventionen]], in denen beispielsweise selbsterklärende (oder auch „sprechende“) Bezeichner/Namen für Variablen etc. zur Verwendung empfohlen/vorgeschrieben werden<ref>{{Literatur|Autor=Ulrich Kohler, Frauke Kreuter|Titel=Datenanalyse mit Stata: Allgemeine Konzepte der Datenanalyse und ihre praktische Anwendung|Auflage=4|Verlag=Oldenbourg Wissenschaftsverlag|Ort=|Datum=2012 |
Um solche Probleme zu vermeiden, existieren häufig [[Namenskonvention (Datenverarbeitung)|Namenskonventionen]], in denen beispielsweise selbsterklärende (oder auch „sprechende“) Bezeichner/Namen für Variablen etc. zur Verwendung empfohlen/vorgeschrieben werden<ref>{{Literatur |Autor=Ulrich Kohler, Frauke Kreuter |Titel=Datenanalyse mit Stata: Allgemeine Konzepte der Datenanalyse und ihre praktische Anwendung |Auflage=4. |Verlag=Oldenbourg Wissenschaftsverlag |Ort= |Datum=2012 |ISBN=978-3-486-70921-6 |Seiten=113 |Kommentar=Datenanalyse mit Stata: Allgemeine Konzepte der Datenanalyse und ihre praktische Anwendung – mit „sprechende Variablennamen“ im Abschnitt „5.6 Beschriftung von Variablen“ |Online=[https://books.google.de/books?id=qjEBKBTGvsYC&pg=PA113&lpg=PA113&dq=Sprechende+Variablennamen&source=bl&ots=eFX3_Me1c7&sig=5EM93MGll4hnaWJodFK_Y_jkc-E&hl=de&sa=X&ved=0ahUKEwj4hreU3oPMAhVLFiwKHXrxC00Q6AEINjAF#v=onepage&q=Sprechende%20Variablennamen&f=false books.google.com]}}</ref> – oder die Verwendung aussagefähiger [[Kommentar (Programmierung)|Kommentare]] im Code. Auch eine sinnvolle Aufteilung des Codes in intuitiv verständliche Funktionen und Klassen trägt zum Verständnis und Übersichtlichkeit bei. |
||
{{Siehe auch|Programmierstil}} |
{{Siehe auch|Programmierstil}} |
||
Zeile 49: | Zeile 49: | ||
== Effiziente Programmierung == |
== Effiziente Programmierung == |
||
Gemäß [[Niklaus Wirth]] zeichnet sich gute Programmierung<ref>{{Literatur | |
Gemäß [[Niklaus Wirth]] zeichnet sich gute Programmierung<ref>{{Literatur |Autor=[[Niklaus Wirth]] |Titel=A Brief History of Software Engineering |Sammelwerk=IEEE Annals of the History of Computing |Band=30 |Nummer=3, Juli–September |Datum=2008 |Seiten=32–39 |Online=[http://www2.computer.org/cms/Computer.org/ComputingNow/homepage/2009/0409/BriefHistoryofSoftwareEng.pdf computer.org] |Format=PDF |KBytes= |Abruf=2009-04-30 |DOI=10.1109/MAHC.2008.33}}</ref> zum einen dadurch aus, dass die Funktionen, die die jeweils verwendete Programmierumgebung bereitstellt, möglichst [[Effizienz (Informatik)|effizient]] genutzt werden. Insbesondere geht es darum, für neue Aufgabenstellungen das Rad nicht immer wieder neu zu erfinden, wenn bestimmte Funktionen schon bereitgestellt werden (zum Beispiel durch die [[Programmierumgebung]] in Form von [[Programmbibliothek]]en). Sie zeichnet sich also vor allem dadurch aus, dass ein guter Überblick über den grundsätzlichen Funktionsumfang und die Systematik der von der Programmierumgebung bereitgestellten Funktionen (die in die zehntausende gehen können) möglich ist. Für eine definierte Aufgabenstellung kann in entsprechenden Dokumentationen dann schnell eine verfügbare Funktion ermittelt, eingesetzt und ggf. erweitert werden. |
||
== Arbeitsmittel == |
== Arbeitsmittel == |
||
Zeile 56: | Zeile 56: | ||
Theoretisch reichen zum Programmieren ein einfacher [[Texteditor]] und ein [[Compiler]]/[[Interpreter]] für die jeweilige Programmiersprache aus. In der Praxis wird jedoch zusätzlich auf eine Reihe von Werkzeugen zurückgegriffen, die typische Programmierarbeiten vereinfachen sollen. Dazu gehören beispielsweise Texteditoren mit speziellen Features wie [[Syntax-Highlighting]], [[Autovervollständigen]] und [[Refactoring]] – wobei der Übergang zur [[Integrierte Entwicklungsumgebung|Integrierten Entwicklungsumgebung (IDE)]] fließend ist. |
Theoretisch reichen zum Programmieren ein einfacher [[Texteditor]] und ein [[Compiler]]/[[Interpreter]] für die jeweilige Programmiersprache aus. In der Praxis wird jedoch zusätzlich auf eine Reihe von Werkzeugen zurückgegriffen, die typische Programmierarbeiten vereinfachen sollen. Dazu gehören beispielsweise Texteditoren mit speziellen Features wie [[Syntax-Highlighting]], [[Autovervollständigen]] und [[Refactoring]] – wobei der Übergang zur [[Integrierte Entwicklungsumgebung|Integrierten Entwicklungsumgebung (IDE)]] fließend ist. |
||
Daneben existieren verschiedene Werkzeuge zur Fehlersuche, |
Daneben existieren verschiedene Werkzeuge zur Fehlersuche, sogenannte [[Debugger]], sowie Programme zur Durchführung [[Statische Code-Analyse|statischer]] und [[Dynamisches Software-Testverfahren|dynamischer Tests]]. Zur Performanzanalyse kann zusätzlich ein [[Profiler (Programmierung)|Profiler]] eingesetzt werden. |
||
Arbeiten mehrere Entwickler an derselben Software, kommen meist [[Versionsverwaltung|Versionierungssysteme]] zum Einsatz, die den Code inklusive früherer Versionen auf einem zentralen Server speichern, auf den alle beteiligten Programmierer Zugriff haben. |
Arbeiten mehrere Entwickler an derselben Software, kommen meist [[Versionsverwaltung|Versionierungssysteme]] zum Einsatz, die den Code inklusive früherer Versionen auf einem zentralen Server speichern, auf den alle beteiligten Programmierer Zugriff haben. |
||
Zeile 65: | Zeile 65: | ||
== Literatur == |
== Literatur == |
||
⚫ | |||
⚫ | |||
== Weblinks == |
== Weblinks == |
||
Zeile 72: | Zeile 71: | ||
{{Commonscat|Computer programming|Programmierung}} |
{{Commonscat|Computer programming|Programmierung}} |
||
{{Wikibooks|Regal:Programmierung|Das Buchregal "Programmierung"}} |
{{Wikibooks|Regal:Programmierung|Das Buchregal "Programmierung"}} |
||
* Joachim Korb: [http://perspektive89.com/2006/12/21/geschichte_der_softwareprogrammierung_freie_software_fur_freiheit_und_gerechtigkeit ''Die Geschichte der Softwareprogrammierung.''] |
* Joachim Korb: [http://perspektive89.com/2006/12/21/geschichte_der_softwareprogrammierung_freie_software_fur_freiheit_und_gerechtigkeit ''Die Geschichte der Softwareprogrammierung.''] perspektive89.com |
||
* [http://www.az2000.de/docs/coding_for_dummies/ ''Einführung ins Programmieren''] (für Neueinsteiger) |
* [http://www.az2000.de/docs/coding_for_dummies/ ''Einführung ins Programmieren''.] az2000.de (für Neueinsteiger). |
||
* [http://www.highscore.de/grundlagen/ ''Allgemeine Grundlagen der Programmierung''] (Online-Buch) |
* [http://www.highscore.de/grundlagen/ ''Allgemeine Grundlagen der Programmierung''.] highscore.de (Online-Buch). |
||
== Einzelnachweise == |
== Einzelnachweise == |
Version vom 22. Oktober 2024, 15:38 Uhr
Programmierung (von altgriechisch πρόγραμμα prógramma „öffentlich und schriftlich bekannt gemachte Nachricht, Befehl“)[1] bezeichnet die Tätigkeit, Computerprogramme zu erstellen und wird der Softwareentwicklung zugerechnet.[2]
Computerprogramme werden mit Hilfe einer Programmiersprache formuliert („codiert“). Die Programmierenden überführen dabei die z. B. im Pflichtenheft vorgegebenen Anforderungen in eine bestimmte Programmiersprache. Teilweise werden dazu Codegeneratoren verwendet, die Teile des Programmcodes auf Basis von Modellen (die im Entwurf entstanden sind) automatisch erzeugen.
Beim Programmieren sind wesentliche Aspekte zur Softwarequalität zu berücksichtigen und durch die Gestaltung des Quellcodes umzusetzen. Siehe dazu als Beispiele: Programmierstil, Benutzerfreundlichkeit,[3] Wiederverwendbarkeit / Modularität, Wartbarkeit.
„Programmieren“ in erweitertem Sinn umfasst neben der Codeerstellung zahlreiche weitere Tätigkeiten, zum Beispiel das Testen (Entwicklertest) des Programms oder das Erstellen der Programmdokumentation. Abgrenzen vom Begriff des Programmierens lassen sich andere Tätigkeiten zur Softwareentwicklung wie beispielsweise das Projektmanagement, die Anforderungsanalyse oder die Datenmodellierung.
Abhängig vom Typ und der Einsatzumgebung von Software (z. B. für Systemsoftware, Spielesoftware, Standardsoftware, Grafiksoftware. usw.) können zur Entwicklung unterschiedliche Verfahren oder/und Werkzeuge (wie Programmiersprachen, Testverfahren etc.) zum Einsatz kommen und/oder von spezialisierten Entwicklern ausgeführt werden.
Je nach angewendetem Vorgehensmodell verlaufen die Aktivitäten zur Programmierung in zeitlich voneinander abgegrenzten Projektphasen, parallel oder iterativ. In der Praxis geschieht das Programmieren häufig in Teamarbeit, mit modernen Entwicklungsmethoden (wie Agile Softwareentwicklung) und Programmierwerkzeugen.
Ähnliche Bedeutungen: Umgangssprachlich bezeichnet man gelegentlich auch das Konfigurieren (das Einstellen/Einrichten) von Haushalts- oder anderen elektrischen Geräten als „Programmieren“. Auch Organisationseinheiten von Unternehmen, in denen Software entwickelt wird, werden oder wurden zum Teil „Programmierung“ genannt.
Geschichte
Charles Babbage beschrieb 1834 eine programmierbare Maschine, die Analytical Engine,[4] welche allerdings nie gebaut wurde. Seine „Notations of calculations for the Analytical Engine“ umfasst 27 Programme. Diese sind in „The Babbage Papers“ des Science Museums von London abrufbar.[5] Die Programme enthalten bereits „Indirekte Adressierung“ und „bedingte Ausführungen“ (IF-THEN-ELSE-Befehle). Diese Dokumente dürften als erste Programme und Programmiersprache bezeichnet werden.
Ada Lovelace übersetzte 1843 eine ursprünglich französische Beschreibung der Analytical Engine von Luigi Federico Menabrea ins Englische und fügte eigene Notizen hinzu. Diese Anmerkungen enthielten einen tabellarischen Plan zur Berechnung der Bernoulli-Zahlen. 1941 realisierte Konrad Zuse mit dem Z3 die erste programmgesteuerte Rechenmaschine, von 1942 an entwickelte er mit Plankalkül die erste höhere Programmiersprache.[6] Die Mathematikerin Grace Hopper schuf 1949 den ersten Compiler, der Quellcode in Maschinencode übersetzt.[7]
Qualitätskriterien
Die Qualität von Software entsteht zu großen Teilen im Rahmen der Tätigkeiten des Programmierens, besonders die folgenden Qualitätskriterien betreffend:
Korrektheit
Ein Programm muss die im Entwurf gemachten Vorgaben korrekt umsetzen. Dazu muss es in der Regel fehlerfrei sein, wobei beim Programmieren meist zwei verschiedene Arten von Fehlern auftreten:
- Syntaxfehler: Fehlerhaft formulierter Quellcode – man verwendet Formulierungen oder Konstrukte, die so nicht in der verwendeten Programmiersprache vorkommen (Tippfehler, Unkenntnis, …). Syntaxfehler können beim Übersetzen vom Compiler/Interpreter oder Parser erkannt werden und verhindern i. d. R. die Programmausführung.
- Semantische Fehler: Das Programm verhält sich nicht wie gewünscht, weil möglicherweise der Algorithmus oder seine Umsetzung fehlerhaft war. Semantische Fehler können in der Regel nicht automatisch erkannt, sondern nur durch gewissenhaftes Testen gefunden werden – beispielsweise in Form von Unittests.
Der Übergang zwischen diesen beiden Fehlerarten ist fließend. Beispielsweise wird ein Tippfehler im Code (z. B. „>“ anstatt „<“ in einem Vergleichsbefehl) zu einem gültigen ausführbaren Programm führen, das Resultat dürfte jedoch falsch sein. An anderer Stelle könnte derselbe Fehler ein Syntaxfehler sein.
Robustheit
Statistisch gesehen wird die meiste Zeit für die Entwicklung von Quelltext benötigt, um auf Fehler oder außergewöhnliche Anwendungs- oder Hardwareumgebungen zu reagieren. Ein Programmtext, der auch bei unvorhergesehenen Fehlern oder ungewöhnlichen Umgebungen sinnvoll reagiert, wird als robust bzw. portabel bezeichnet. Geübte Programmierer können die möglichen Fehler und Laufzeitumgebungen gut einschätzen und strukturieren das Programm und seinen Quelltext dementsprechend. Der Zeitdruck bei der Entwicklung von Anwendungen stellt selbst an erfahrene Programmierer immer höchste Ansprüche hinsichtlich dieses Kriteriums.
Wartbarkeit
Damit eine Software dauerhaft funktioniert, muss sie wartbar sein. Das heißt, Änderungen wie Bugfixes, Anpassungen und neue Features müssen ohne großen Aufwand eingepflegt werden können. Dies erfordert vor allem, dass der Programmierer keinen zu kurzen, „kryptischen“ Quelltext (oder Quellcode) erzeugen soll, der für andere Entwickler nicht oder nur mit hoher Einarbeitungszeit verständlich ist.
Um solche Probleme zu vermeiden, existieren häufig Namenskonventionen, in denen beispielsweise selbsterklärende (oder auch „sprechende“) Bezeichner/Namen für Variablen etc. zur Verwendung empfohlen/vorgeschrieben werden[8] – oder die Verwendung aussagefähiger Kommentare im Code. Auch eine sinnvolle Aufteilung des Codes in intuitiv verständliche Funktionen und Klassen trägt zum Verständnis und Übersichtlichkeit bei.
Effizienz
In der Regel stehen einem Programm nur begrenzte Ressourcen (Laufzeit, Speicherverbrauch, Bandbreite) zur Verfügung. Gute Programmierung kann dazu beitragen, unnötigen Ressourcenverbrauch zu reduzieren. Beispielsweise erfolgt dies, indem bei Verwendung großer Datenmengen an mehreren Stellen im Programm nicht jeweils der gesamte Datensatz kopiert wird, sondern nur die Adresse übertragen wird, an der die Daten gespeichert werden.
Effiziente Programmierung
Gemäß Niklaus Wirth zeichnet sich gute Programmierung[9] zum einen dadurch aus, dass die Funktionen, die die jeweils verwendete Programmierumgebung bereitstellt, möglichst effizient genutzt werden. Insbesondere geht es darum, für neue Aufgabenstellungen das Rad nicht immer wieder neu zu erfinden, wenn bestimmte Funktionen schon bereitgestellt werden (zum Beispiel durch die Programmierumgebung in Form von Programmbibliotheken). Sie zeichnet sich also vor allem dadurch aus, dass ein guter Überblick über den grundsätzlichen Funktionsumfang und die Systematik der von der Programmierumgebung bereitgestellten Funktionen (die in die zehntausende gehen können) möglich ist. Für eine definierte Aufgabenstellung kann in entsprechenden Dokumentationen dann schnell eine verfügbare Funktion ermittelt, eingesetzt und ggf. erweitert werden.
Arbeitsmittel
Theoretisch reichen zum Programmieren ein einfacher Texteditor und ein Compiler/Interpreter für die jeweilige Programmiersprache aus. In der Praxis wird jedoch zusätzlich auf eine Reihe von Werkzeugen zurückgegriffen, die typische Programmierarbeiten vereinfachen sollen. Dazu gehören beispielsweise Texteditoren mit speziellen Features wie Syntax-Highlighting, Autovervollständigen und Refactoring – wobei der Übergang zur Integrierten Entwicklungsumgebung (IDE) fließend ist.
Daneben existieren verschiedene Werkzeuge zur Fehlersuche, sogenannte Debugger, sowie Programme zur Durchführung statischer und dynamischer Tests. Zur Performanzanalyse kann zusätzlich ein Profiler eingesetzt werden.
Arbeiten mehrere Entwickler an derselben Software, kommen meist Versionierungssysteme zum Einsatz, die den Code inklusive früherer Versionen auf einem zentralen Server speichern, auf den alle beteiligten Programmierer Zugriff haben.
Siehe auch
Literatur
- Michael Sperber, Herbert Klaeren: Schreibe dein Programm! Einführung in die Programmierung. Tübingen Library Publishing, Tübingen 2024, ISBN 978-3-947251-88-9
Weblinks
- Joachim Korb: Die Geschichte der Softwareprogrammierung. perspektive89.com
- Einführung ins Programmieren. az2000.de (für Neueinsteiger).
- Allgemeine Grundlagen der Programmierung. highscore.de (Online-Buch).
Einzelnachweise
- ↑ Wilhelm Pape, Max Sengebusch (Bearb.): Handwörterbuch der griechischen Sprache. 3. Auflage, 6. Abdruck, Vieweg & Sohn, Braunschweig 1914; zeno.org
- ↑ Was ist Softwareentwicklung? IBM; abgerufen am 18. Juni 2024
- ↑ Sebastian Dörn: Programmieren lernen und Algorithmen verstehen. Abgerufen am 12. Januar 2018.
- ↑ computerhistory.org
- ↑ collection.sciencemuseumgroup.org.uk
- ↑ link.springer.com
- ↑ Grace Hopper. Yale University; abgerufen am 7. Juni 2016
- ↑ Ulrich Kohler, Frauke Kreuter: Datenanalyse mit Stata: Allgemeine Konzepte der Datenanalyse und ihre praktische Anwendung. 4. Auflage. Oldenbourg Wissenschaftsverlag, 2012, ISBN 978-3-486-70921-6, S. 113 (books.google.com – Datenanalyse mit Stata: Allgemeine Konzepte der Datenanalyse und ihre praktische Anwendung – mit „sprechende Variablennamen“ im Abschnitt „5.6 Beschriftung von Variablen“).
- ↑ Niklaus Wirth: A Brief History of Software Engineering. In: IEEE Annals of the History of Computing. Band 30, 3, Juli–September, 2008, S. 32–39, doi:10.1109/MAHC.2008.33 (computer.org [PDF; abgerufen am 30. April 2009]).