NG Programmiersprache?



  • 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 von std::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 und Container eine IS-A-Beziehung (im Sinne des LSP) besteht. Und wenn es sinnvoll ist, ein Panel oder Window als Container abstrakt anzusprechen, was spricht dagegen? Ich habe ja schon Vorteile genannt, z.B. müsste

    void 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 ^^



  • Zeus schrieb:

    Sag blos du willst in eine Ein-Paradigma-Programmiersprache arbeiten? Du "kotzt" doch greade wegen Java ab ^^

    Du vergleichst Äpfel mit Birnen. Java versucht allem krampfhaft seine Objektorientierung für Arme aufzuzwingen, das heißt aber noch lange nicht, dass eine rein-funktionale Sprache schlecht wäre.



  • Mr. N schrieb:

    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.

    Du vergisst was: Java Basic PHP...



  • Mr. N schrieb:

    Zeus schrieb:

    Sag blos du willst in eine Ein-Paradigma-Programmiersprache arbeiten? Du "kotzt" doch greade wegen Java ab ^^

    Du vergleichst Äpfel mit Birnen. Java versucht allem krampfhaft seine Objektorientierung für Arme aufzuzwingen, das heißt aber noch lange nicht, dass eine rein-funktionale Sprache schlecht wäre.

    Das musst du mir genauer erläutern! Sonst hake ich das als böswillige Unterstellung ab.



  • Zeus schrieb:

    Mr. N schrieb:

    Du vergleichst Äpfel mit Birnen. Java versucht allem krampfhaft seine Objektorientierung für Arme aufzuzwingen, das heißt aber noch lange nicht, dass eine rein-funktionale Sprache schlecht wäre.

    Das musst du mir genauer erläutern! Sonst hacke ich das bösewillige Unterstellung ab.

    In rein objektorientierten Sprachen (in Java-Art*) ist es schwierig, Konzepte wie Addition auszudrücken:

    obj1.add(obj2)
    

    - nicht gerade elegant!

    Aber kannst du mir etwas konkretes nennen, was in funktionalen Programmiersprachen nicht gut geht? Zumindest nicht so gut wie in einer Sprache, die Objektorientierung unterstützt.

    ~Den Satz "Sonst hacke ich das bösewillige Unterstellung ab" verstehe ich beim besten Willen nicht. Was soll das bedeuten?~

    ----

    (*) Mir ist bekannt, dass es auch objektorientierte Sprachen mit Multi-Dispatch gibt, aber die sind leider relativ exotisch.



  • abhaken und nichts ab hacken



  • Zum Punkt, du hast hergeleitet, dass ich etwas Vergleiche, was ich nicht getan habe. Ich hab eine Frage für eine Kategorie gestellt und Java als Beispiel genommen. Eigentlich dachte ich, dass du weißt, dass man Aussagen für Beispiel nicht auf Kategorien verallgemeinern darf und schon gar nicht auf andere Kategorie.

    Außerdem ist Java keine pure objektorientierte Programmiersprache.

    Wenn du eine pure objektorientierte Programmiersprache mit Operatordefinition (nicht Überladung!) suchst, dann nimm Cecil. Diese Sprache hat aber wirklich keine Verbreitung jenseits der Uni.



  • Zeus schrieb:

    Außerdem ist Java keine pure objektorientierte Programmiersprache.

    "pur objektorientiert" gibt es nicht.



  • Mr. N schrieb:

    Zeus schrieb:

    Mr. N schrieb:

    Du vergleichst Äpfel mit Birnen. Java versucht allem krampfhaft seine Objektorientierung für Arme aufzuzwingen, das heißt aber noch lange nicht, dass eine rein-funktionale Sprache schlecht wäre.

    Das musst du mir genauer erläutern! Sonst hacke ich das bösewillige Unterstellung ab.

    In rein objektorientierten Sprachen (in Java-Art*) ist es schwierig, Konzepte wie Addition auszudrücken:

    obj1.add(obj2)
    

    - nicht gerade elegant!

    Aber kannst du mir etwas konkretes nennen, was in funktionalen Programmiersprachen nicht gut geht? Zumindest nicht so gut wie in einer Sprache, die Objektorientierung unterstützt.

    Prozesse beschreiben, oder Objekte darstellen geht in rein funktionalen Programmiersprachen genauso gut, wie Funktionen beschreiben in "rein" Objektorientierten Sprachen mit "Objekt.Methode(Parameter)-Syntax". Ein Prozessor führt Prozesse aus (Prozedurale Programmierung), in Software müssen meistens realitätsnahe Objekte dargestellt werden (Objektorientierte Programmierung). Nicht, dass es keine guten Gründe für funktionale Programmierung gäbe, aber ich glaube ein sehr wichtiger ist einfach der, dass die meisten studierten Programmierer Informatiker (Mathematiker) sind. Da liegt das sehr mathematische Modell natürlich nahe.



  • volkard schrieb:

    Zeus schrieb:

    Außerdem ist Java keine pure objektorientierte Programmiersprache.

    "pur objektorientiert" gibt es nicht.

    Begründet oder erklärt durch?


Anmelden zum Antworten