NG Programmiersprache?
-
Bei Qt:
QWidget
Inherits QObject and QPaintDevice.In Scott Meyers Effecitve C++ ist auch ein Beispiel drin, das zeigt, wo man MI verwenden _kann_. Man braucht es nicht häufig, aber es gibt Einsatzgebiete.
-
thatway schrieb:
Oder nicht doch besser Has-A Container?
Welchen Vorteil hätte das hier?
-
Nachfrager schrieb:
thatway schrieb:
Oder nicht doch besser Has-A Container?
Welchen Vorteil hätte das hier?
Keine Konflikte mit anderen Methoden. Einige Methoden von Container sind für Panel relativ sinnlos (Zugriff auf Index oder Iterator).
-
Cute schrieb:
Bei Qt:
QWidget
Inherits QObject and QPaintDevice.Bei Qt ist das aber wohl auch so aufgrund der tatsache, dass QPaintdevice nicht von QObject erbt. Und QObjects kann man nicht kopieren, was bei einem paintdevice natürlich ungünstig wäre.
Das ganze ist bei Qt dann wohl also eher aufgrund des designs der klassen so entstanden, bzw aufgrund der einschränkungen von QObject.Ich denke, man kann durchaus sagen, dass bis auf weniger spezialfälle hauptsächlich in frameworks "echte" mehrfachvererbung eher nicht nötig ist. Und die wenigen spezialfälle hängen idR doch an irgendwelchen einschränkungen im klassendesign (bei Qt eben QObject).
Bei Qt ist die mehrfachvererbung eben auch eher die ausnahme.
-
Next Generation Programmiersprache? Und alle labern von C++, Qt und ueber Vergangenheit.
-
aber komm jetzt nicht mit Funktionalen Programmiersprachen. Die sind ja auch schon uralt.
-
qwerttzy schrieb:
aber komm jetzt nicht mit Funktionalen Programmiersprachen. Die sind ja auch schon uralt.
Trotzdem die Zukunft.
Die Tatsache, dass imperative Programmiersprachen für viele moderne Probleme (Concurrency bla blub) an ihre Grenzen stoßen ist da wohl der Stein, der alles ins Rollen bringt. Aber natürlich sind funktionale Programmiersprachen auch ohne das eine Verbesserung, weil sie einfach ein abstrakteres Programmieren erlauben.
-
Dann werf ich mal rein: Haben object-funktionale Programmmiersprache zukunft?
In diese Art gehören Scala(scala-lang.org) und Nemerle(nemerle.org).
-
Mr. N schrieb:
Aber natürlich sind funktionale Programmiersprachen auch ohne das eine Verbesserung, weil sie einfach ein abstrakteres Programmieren erlauben.
Inwiefern abstrakter?
-
thatway schrieb:
Nachfrager schrieb:
thatway schrieb:
Oder nicht doch besser Has-A Container?
Welchen Vorteil hätte das hier?
Keine Konflikte mit anderen Methoden. Einige Methoden von Container sind für Panel relativ sinnlos (Zugriff auf Index oder Iterator).
Du hast den von mir beschriebenen
Container
falsch verstanden. Das ist kein Container im Sinne vonstd::vector
, sondern ein Behälter für andere GUI-Komponenten. Als Schnittstelle und Implementierung hätte ich mir sowas vorgestellt (um es nicht zu kompliziert zu machen):class Container { public: void Attach(const Component& subComponent); void Detach(const Component& subComponent); private: std::vector<Component*> mySubComponents; };
Ich finde den Namen "Container" auch schlecht, womöglich werde ich sogar einen Thread dazu aufmachen.
Ich gehe schon davon aus, dass zwischen
Panel
bzw.Window
undContainer
eine IS-A-Beziehung (im Sinne des LSP) besteht. Und wenn es sinnvoll ist, einPanel
oderWindow
alsContainer
abstrakt anzusprechen, was spricht dagegen? Ich habe ja schon Vorteile genannt, z.B. müsstevoid ListAllComponents(const Container& c);
nur einmal implementiert werden. Oder man könnte Variablen
Container* var;
haben.
Man braucht Mehrfachvererbung eher selten, das stimmt. Was man ab und zu sieht, sind jedoch Beziehungen wie
class Derived : public Base, private boost::noncopyable { ... };
Alleine schon deswegen fände ich es unangebracht, Mehrfachvererbung zu verbieten.
-
Zeus schrieb:
Dann werf ich mal rein: Haben object-funktionale Programmmiersprache zukunft?
In diese Art gehören Scala(scala-lang.org) und Nemerle(nemerle.org).Ich weiß es nicht, vielleicht. Es ist wichtig, dass man die Abstraktion und Composability nicht verliert. Ich muss mir Scala etc. noch ernsthaft anschauen, aber mein erster Eindruck ist, dass die da 'ne Menge Features haben, die nicht so ganz zusammenpassen, und es ein bisschen so wird wie in C++. Ich habe z.B. eine Übersetzung von Monads in Scala gesehen, und so wirklich elegant sah das nicht aus, aber vielleicht kann ich Scala einfach noch nicht gut genug.
So etwas wie Monads sind wichtig, damit man all diese Dinge auf der gleichen Basis aufbauen kann:
-- Liest Zeilen ein und gibt sie wieder aus. forever $ do x <- getLine putStrLn x
do x <- [1..] y <- [1..x] (x, y) -- das selbe wie [ (x, y) | x <- [1..], y <- [1..x] ] (also eine List comprehension) -- = [(1,1),(2,1),(2,2),(3,1),(3,2),(3,3),(4,1),(4,2),(4,3),(4,4),...]
do n <- digitToInt <$> digit replicateM n letter -- Ein Parser, der eine Ziffer liest, und danach diese Anzahl an Buchstaben. -- Also "4abcd" ist gültig, ebenso "1a", aber "2a" ist ungültig.
-
Mr. N schrieb:
qwerttzy schrieb:
aber komm jetzt nicht mit Funktionalen Programmiersprachen. Die sind ja auch schon uralt.
Trotzdem die Zukunft.
Mir gefällt das Konzept funktionaler Programmiersprachen ebenfalls sehr. Ich habe mich vor einiger Zeit ein wenig mit Haskell beschäftig und es bietet wirklich interessante Möglichkeiten, die in anderen, verbreiteteren Sprachen nicht oder weniger elegant möglich sind. Man kann seinen Horizont enorm erweitern.
Jedoch würde ich das Ganze nicht nur euphorisch sehen. Warum hat sich objektorientierte Programmierung als heutiges Programmierparadigma etabliert und ist derart beliebt? Weil sie mit Objekten eine eine für den Menschen intuitive Möglichkeit bietet, das Programm zu beschreiben. Man kann damit viele Probleme aus der Realität verständlich abbilden. Bei rein funktionalen Programmiersprachen, die ihre Ursprünge eher in der Mathematik haben, ist das schon viel schwieriger. Ich denke, der durchschnittliche Programmierer hat viel mehr Mühe, sich ein funktionales Denken anzueignen als ein objektorientiert-prozedurales. Das dürfte auch ein zentraler Grund für die geringe Verbreitung rein funktionaler Programmiersprachen sein.
Allerdings gehen Programmiersprache wie C# oder C++ bereits einen Weg in Richtung funktionale Programmierung, bei C++ kommen mit dem neuen Standard z.B. Lambda-Ausdrücke als Sprachelement dazu. High-Order-Funktionen gibts auch schon länger. Meiner Meinung nach wird sich rein funktionales Programmieren nicht so schnell durchsetzen, vielmehr dürfte es eine Mischung mit momentanen Paradigmen sein.
-
Nexus schrieb:
Ich denke, der durchschnittliche Programmierer hat viel mehr Mühe, sich ein funktionales Denken anzueignen als ein objektorientiert-prozedurales.
Wieso muss man sich immer an den durchschnittlichen Programmierern ausrichten?
Und ja, ich habe mehrere Anläufe gebraucht, bis ich Haskell verstehen konnte. Aber das war es wert.
-
Mr. N schrieb:
Wieso muss man sich immer an den durchschnittlichen Programmierern ausrichten?
Weil dieser massgeblich an der Verbreitung einer Programmiersprache beteiligt ist.
Ich sagte ja nicht, man sollte sich als Programmierer selbst nach ihm ausrichten.
-
Mr. N schrieb:
Nexus schrieb:
Ich denke, der durchschnittliche Programmierer hat viel mehr Mühe, sich ein funktionales Denken anzueignen als ein objektorientiert-prozedurales.
Wieso muss man sich immer an den durchschnittlichen Programmierern ausrichten?
Was anderes kann nicht die Zukunft sein.
-
einfach schrieb:
Mr. N schrieb:
Nexus schrieb:
Ich denke, der durchschnittliche Programmierer hat viel mehr Mühe, sich ein funktionales Denken anzueignen als ein objektorientiert-prozedurales.
Wieso muss man sich immer an den durchschnittlichen Programmierern ausrichten?
Was anderes kann nicht die Zukunft sein.
http://de.wikipedia.org/wiki/Paretoprinzip
Das kann man auch auf Programmierer ausweiten: 20% der Entwickler sind für 80% der Produktivität verantwortlich.
-
Ich glaube du verzettelst dich da MrN, abgesehen davon, dass das auf riener Spekulation beruht glaube ich selbst falls es so ist nicht daran, dass sich die Programmiersprachen dieser Gurus durchsetzen
MfG SideWinder
-
SideWinder schrieb:
Ich glaube du verzettelst dich da MrN, abgesehen davon, dass das auf riener Spekulation beruht glaube ich selbst falls es so ist nicht daran, dass sich die Programmiersprachen dieser Gurus durchsetzen
Es wird sich auf jeden Fall eine mindestens teilweise funktionale Sprache in der breiten Masse durchsetzen. Schließlich bekommt sogar C# manche funktionalen Features und Sprachen wie Scala, Clojure und F# sind auch relativ beliebt.
Natürlich geht mir das nicht weit genug, aber das ist nur meine Meinung.
(Das "Verzetteln" nehm ich dir übel.)
PS: Haskell wird übrigens unter anderem von Leuten von Microsoft Research entwickelt, als Microsoft-Fanboy wird dich das ja bestimmt positiver stimmen. :p
-
Du hast ohnehin schon gewonnen, in zweieinhalb Monaten geht's bei mir für vier Monate mit Haskell los, danach bin ich hoffentlich ebenfalls indoktriniert
Ja, wiedereinmal wird sich mischmasch durchsetzen
MfG SideWinder
-
SideWinder schrieb:
Du hast ohnehin schon gewonnen, in zweieinhalb Monaten geht's bei mir für vier Monate mit Haskell los, danach bin ich hoffentlich ebenfalls indoktriniert
Ja, wiedereinmal wird sich mischmasch durchsetzen
MfG SideWinder
Sag blos du willst in eine Ein-Paradigma-Programmiersprache arbeiten? Du "kotzt" doch greade wegen Java ab ^^