Diskussion:Bjarne Stroustrup

aus Wikipedia, der freien Enzyklopädie
Letzter Kommentar: vor 12 Jahren von Scary.Hallo in Abschnitt Externer Link auf Stroustrups Website
Zur Navigation springen Zur Suche springen

Verbesserungswürdig

[Quelltext bearbeiten]

Der Artikel ist nicht sehr gut. Was seine Arbeit in Bezug auf C++ angeht, empfiehlt sich das Lesen von the Design and Evolution of C++. Da beschreibt er genau, warum er die Sprache wie entworfen hat. Ich habe es gerade nicht hier, sonst würde ich mir die Mühe machen, mehr Details zu geben.

Was ich noch im Kopf habe:

Angefangen hat es mit Ole-Johan Dahls Simula, einer Sprache für Simulation. Von dort hat Stroustrup die Idee der Klassen übernommen. Er schrieb dann einen Übersetzter der "C with Classes" nach C übersetzt, dem Vorläufer von C++. Der erste C++-Compiler heißt "cfront".

Sprachlich hat C++ ziemlich viele Metafeatures, die viele verschiedene Programmierstile, ja sogar -paradigmen erlauben, wie z.B. generische Programmierung.

C++ ist ziemlich einzigartig, weil es sowohl recht low-level (Hardware-nah) wie C ist (C++ ist mit Abwärtskompatibilität entworfen worden, also derart, dass fast alle C-Programme auch gültige C++-Programme sind) und daher auf Effizienz achtet, was Rechenzeit- und Speicherverbrauch angeht, als auch high-level (höheres Abstraktionsniveau) Programmierung zulässt, insbesondere objektorientierte Programmierung.

Vernachlässigt wurden beim Entwurf von C++ die Bibliotheken. Java, das zu Anfang selbst von Sun als vereinfachtes C++ vermarktet wurde (zu einer Zeit, als Programmierer rar waren), hat gezeigt, welch große Erleichterung ein umfangreicher, standardisierter Satz an Bibliotheksfunktionalität bringt. Erst spät wurde eine umfangreiche Standardbibliothek definiert, weitere Beinahe-Standards werden durch das Boost Projekt (www.boost.org) gesetzt.

Auch war die Sprache derart komplex in einigen Bereichen, dass erst spät Compiler auf den Markt kamen, die den Sprachstandard vollständig implementierten.

Java hat auch gezeigt, dass die Interpretation auf einer virtuellen Maschine (Laufzeitoptimiert durch Just-in-Time-Übersetzung) nicht nur von Nachteil ist, sondern auch Vorteile bietet (neben Laufzeitprofiling ist auch Reflexion, Nachladen von Modulen zur Laufzeit einfach möglich). Im Prinzip wäre es auch möglich, vom traditionellen per Compiler übersetzten C++ auf ein ähnlich Java interpretiertes Auführungsmodell überzugehen.

Ein weiterer Ableger von C++ ist neben Java die Programmiersprache C# von Microsoft, das wiederum einige von Java beigesteuerte Ideen aufgreift.

Dahl (und weiter Software Pioniere) kann man übrigens im Netz sehen: http://www.sdm.de/en/it-wissen/themen/sdmkonf-2001/

Marc van Woerkom (ohne Datum signierter Beitrag von Marc van Woerkom (Diskussion | Beiträge) 19:47, 8. Jul. 2004 (CEST)),Beantworten
(nachträglich bearbeitet: (nicht signierter Beitrag von 80.136.155.43 (Diskussion) 20:43, 20. Sep. 2005 (CEST)))Beantworten

Virtuelle Maschinen

[Quelltext bearbeiten]

Virtuelle Maschinen haben den Nachteil, dass sie sehr Ressourcenfressend sind und das System ziemlich abbremsen und belasten. Bei 32-bit und 8-bit Prozessoren, die schon sehr wenig Ressourcen haben ist es ein muss, dass die Software sehr Ressourcenschonend und hardwarenah programmiert werden soll, so wie es bei C/C++ sein soll.

Beispiel bei einem ARM Prozessor, der mit nur 200MHz betrieben wird ... -- 188.20.126.227 15:25, 11. Okt. 2010 (CEST) GottfriedBeantworten

[Quelltext bearbeiten]

Der Link auf die Bjarne Stroustrups Homepage bei AT&T stimmt nicht mehr. --Scary.Hallo (Diskussion) 12:10, 16. Jul. 2012 (CEST)Beantworten