Warum programmiert ihr in C?



  • Nun irgendwie traurig, dass hier soviele Scheinargumenten reinkommen 😞

    @Volkard
    Btw die C Version läuft bei mir stabil immer schneller als C++ Variante.

    VS 2010 Release /O2 (Max Speed)

    c:8,16s
    cpp(Funktionszeiger):8,26s
    cpp:4,5s



  • -lowbyte- schrieb:

    Und zwar aus dem Grund weil heute niemand mehr richtig C++ lernen will oder kann, da in der heutigen Zeit in der die Leute immer fauler werden, vieles vergessen oder einfach viel zu viel Zeit gebraucht um sich überhaupt in der Sprache zurechtzufinden. Deshalb spricht für mich so vieles für C. Es ist zwar schlank aber ein bisschen schwer zu erlernen für den Anfänger, doch man versinkt nicht darin. Und mann kann sich mit den eigentlichen Problemen befassen, und lernt noch was dabei. Wer einmal C begriffen hat, und mit der Zeit viele erfahrungen gesammelt hat wird den schlankeren, portableren , und performanteren Code schreiben.

    Also ganz ehrlich: wenn die Person schon zu dumm/faul fuer C++ ist, wuerde ich sie auf keinen Fall an C ran lassen. In C muss man viel mehr aufpassen was man tut - da sind kleine Fehler oft tragisch.

    Python ist da eine viel viel bessere Wahl. Sich mit Python in den Fuss zu schiessen ist schwer. Bei C passiert das jeden mal.

    @Zeus:
    Du sollst auch nicht die Funktionszeiger Variante nehmen sondern die Funktionsobjekt Variante. Und du sollst sie nicht C++ variante nennen 😉



  • Super. Geilen wir uns jetzt an realitsfremden Minibeispielen auf, welches unter welchen Compilerflags und HW und BS um ein paar Millisekunden schneller ist?
    Was für ein Witzthread.



  • Zeus schrieb:

    @Volkard
    Btw die C Version läuft bei mir stabil immer schneller als C++ Variante.
    VS 2010 Release /O2 (Max Speed)
    c:8,16s
    cpp(Funktionszeiger):8,26s

    Ja, daß qsort bei mir langsamer war, hat mich auch überrascht. Immerhin kann der int pro Aufruf mehr Information liefern.



  • @volkard: Lässt du gelten, dass es viel schwieriger ist, etwas gescheit in C++ zu implementieren als in C? Laut dir existiert ja beispielsweise keine zufriedenstellende Lösung für grundlegende Fähigkeiten wie streams.

    Die OOP-Argumente von C-lern kann ich nicht nachvollziehen, dank der Glib kann man in C genauso objektorientiert programmieren wie unter C++, hat nur mehr Kontrolle. Ausserdem sind Ereignisse einfacher handzuhaben.
    Mit den GString ist ein guter string vorhanden und richtig zeitkritische Abschnitte lassen sich ohne grossen Stilbruch einfügen. In C++ habe ich den Stress, dass alles in RAII gewrappt werden muss.

    realistee schrieb:

    Ich frag mich wie viele der Cler hier schon an richtig großer Software geschrieben haben

    Bezüglich in C geschriebene Software muss sich C++ hinten anstellen, Microsoft-Software (Windows XX, Word), Firefox und KDE sind alle nicht besonders performant, bei Linux, Emacs, mutt und GNOME sieht das alles gleich besser aus. Klar, diese Produkte sind weniger "aufs Äussere bedacht", sie haben halt die Philosophie von C übernommen. Aber das sind keine objektiven Argumente gegen C++.

    Meine Meinung zusammengefasst: Wenn man in C++ C-artig programmiert, sind beide Sprachen etwa gleich schnell, sobald templates verwendet werden ist das C++-Programm grösser und wenn eine echte Klassenhierarchie aufgestellt wird (streams) kann man den Geschwindigkeitsunterschied zugunsten von C leicht messen. In C habe ich den Blick aufs Wesentliche.



  • Cönner schrieb:

    @volkard: Lässt du gelten, dass es viel schwieriger ist, etwas gescheit in C++ zu implementieren als in C?

    Nein, ganz bestimmt nicht in dieser Allgemeinheit.

    Cönner schrieb:

    Laut dir existiert ja beispielsweise keine zufriedenstellende Lösung für grundlegende Fähigkeiten wie streams.

    Damals war C++ voll neu, und keiner, auch Stroustrup nicht, wußte wie man in C++ programmieren sollte. Und sie sind anscheinend nicht schlecht genug, daß man sie ersetzt. Soo arg beschleunigen kann man streams nämlich gar nicht. Damals gab es keine Templates und keine Exceptions! 😮

    Cönner schrieb:

    Meine Meinung zusammengefasst: Wenn man in C++ C-artig programmiert, sind beide Sprachen etwa gleich schnell, sobald templates verwendet werden ist das C++-Programm grösser und wenn eine echte Klassenhierarchie aufgestellt wird (streams) kann man den Geschwindigkeitsunterschied zugunsten von C leicht messen. In C habe ich den Blick aufs Wesentliche.

    Meine Meinung klingt ähnlich: Wenn man in C++ sorgsam performance-orientiert programmiert (wozu es nötig ist, auch ein wenig in C zu Hause zu sein), muß man keinen Takt mehr zahlen als mit C. Auch nicht bei Verwendung komplexer Objektorientierung. Theoretisch sogar ein paar weniger, aber das wird nicht messbar sein.
    Man kann aber auch leicht dem Arbeitgeber oder Kunden nachgeben und mit recht wenig Mühe Sachen hinhudeln, die sind dann schneller fertiggestellt, laufen aber ein wenig langsamer. Kann man das auch in C? Falls ja, sind wir doch eigentlich quitt.



  • Cönner schrieb:

    Bezüglich in C geschriebene Software muss sich C++ hinten anstellen, Microsoft-Software (Windows XX, Word), Firefox und KDE sind alle nicht besonders performant, bei Linux, Emacs, mutt und GNOME sieht das alles gleich besser aus. ... Aber das sind keine objektiven Argumente gegen C++.

    Trotzdem möchte ich kurz darauf eingehen, weil andere Teilnehmer das in wütenden Beweisführungen vortragen.
    Nur mal so eine Idee:

    Es gibt Leute, die schlichte Eleganz mögen. Leute, für die Einfachheit was tolles ist. Leute, die davon überzeugt sind, daß man für ein schnelles Auto zuerst mal auf den elektisch einfahrbaren Kofferraumgriff verzichten sollte, satt hinten einen Spoiler dranzuschrauben. So Leute mag ich. Die gehen eher zu Gnome als zu KDE, eher zu Linux als zu Windows. Ich nenne sie im Folgenden mal KISS-Leute.

    Vor 20 Jahren war C++ technisch langsamer als C. Man hat für den (damals) Luxus der Objektorientierung bezahlen müssen.

    Die KISS-Leute gingen nicht nur mehr zu Gnome, sondern auch mehr zu C. Logisch.

    Jetzt ist C++ technisch nicht mehr langsamer.

    sprungmarke:

    Die KISS-Leute sind aber noch mehr bei Gnome und C zu finden. DADURCH sind C-Programme oft bescheidener und schneller.

    Und jetzt kommt die sich selbsterfüllende Phophezeihung: http://de.wikipedia.org/wiki/Selbsterfüllende_Prophezeiung

    Wenn ich ein neuer KISS-Leut bin, schaue ich mir KDE/C++ an und Gnome/C und stelle fest, daß mir Gnome/C mehr gefällt.
    Wenn ich ein neuer Bloat-Leut bin, schaue ich mir KDE/C++ an und Gnome/C und stelle fest, daß mir KDE/C++ mehr gefällt.

    goto sprungmarke;

    ---

    Kleine Anektode am Rande. Hier war mal einer, der hat ein Virenschutzprogramm für Win mitentwickelt und beworben. Ich wünste mir entschieden ein Kommandozeileninterface, damit ich nach Gusto den Prüfer durchlaufen lassen kann. Auch in den Windows-Taskplaner reintun. Nix da! Geschäftsleitung erlaubt sowas nicht. Stattdessen wird ein eigener Taskplaner gebastelt und mitgeliefert, der natürlich dann mitlaufen muß und wieder ein wenig Rechenzeit und RAM klaut.
    Jeder Virenscanner oder Defragmentierer, den man für Windows kaufen kann, hat so einen Taskplaner dabei. Es wird aus Prinzip nicht der eingebaute verwendet. Seltsam das. Und unangenehm.

    Oder jüngst erlebt. Ich benutze im Moment ein gentoo-Linux auf USB-Stick. Bin ein wenig am rumfummeln. Da gibt es einen recht simplen Texteditor namens Mousepad. Ich war an sich glücklich damit. Bis ich ihn mal als root ausgeführt hatte. Da wird das Textfenster um eine Zeile verkleinert und oben schiebt sich eine feste rot hinterlegte Zeile ein "Warning, you are using the root account, you may harm your system."
    Was soll der Quatsch? 😡



  • realistee schrieb:

    Ich frag mich wie viele der Cler hier schon an richtig großer Software geschrieben haben mit GUI, Netzwerk, Datenbankanbindung etc. Wird bestimmt sehr übersichtlich der Code mit purem C. 😃

    Cler leben halt doch eher in ihrer kleinen Treiber/Hack-Welt, die eher dem Jahr 1980 als 2010 entspricht. In der realen Welt ist es den Kunden scheissegal ob die Anwendung 2% langsamer läuft. Der will einfach schnellstmöglich Ergebnisse, denn SW Entwicklung ist schweineteuer.

    Aber ich erwarte nicht, dass das unsere unstudierten Cler verstehen.

    also zugegeben hab ich noch nie eine richtig große software erstellt. aber wer hat das schon? übersichtlichkeit kommt durch schnittstellen. ob ich meine funktionen jetzt mit

    my_class::abc()

    oder über

    my_class_abc()

    aufrufe macht keinen großen unterschied... einzig die übergabe des für oop notwendigen parameter könnte man als argument anführen. was übersichtlich ist und was nicht hängt vom entwickler ab. hingerotztes c++ ist genau so unleserlich wie schlampiges c. wenn man sich aber ein bischen mühe gibt, kann man in beiden saubere/leserliche/wartbare software schreiben.



  • evtl. sollte ich noch anmerken, dass die größten bisher geschriebenen software pakete in c daher kommen?



  • Ich denke der Grund warum es mehr C-Programmierer gibt als die die C++ können liegt darin begründet dass C++ zu den am schwersten zu lernenden Sprachen gehört. Wenn man es denn sehr gut kann ist es extrem schnell und auch meist ein Allzweckwerkzeug, aber das können eben nicht vielen und haben auch irgendwann keine Lust mehr so weit zu gehen da es heutzutage mehr als genug Alternativen gibt.

    Oft wird sogar nur noch extrem zeitkritische oder systemnahe Geschichten in C oder C++ als Lib geschrieben und der Rest eben in OOP Hochsprachen die schnell zu lernen sind und viele Fehler von vornerein gar nicht erst zu lassen.

    Ich denke daran wird sich auch nichts mehr ändern schließlich dreht sich die Welt immer schneller und schon gutes OOP zu lernen dauert seine Zeit und irgendwann will man neben der ganzen zu lernenden Informatik hinter allem auch mal anfangen zu arbeiten. Eine Sprache die dann noch mal viel Zeit abverlangt hat du heute keine große Chance mehr und wird nur noch genutzt weil einige Entwickler nichts anderes können oder man alten Code weiterverwenden muss.



  • Ich programmiere lieber in C++, denn es bietet mir Funktionalitäten, die mir C nicht bietet, z.B.:

    - Operatorenüberladung
    - Vererbung
    - Konstruktoren und Destruktoren ermöglichen automatische Initialisierung bzw. Freigabe von Speicher. Auf sowas muss ich in C extra achten.
    - Daten und Zugriffsfunktionen sind in einen Objekt zusammengefasst
    - Exceptions, die eine einfachere Fehlerbehandlung ermöglichen.

    C++ ist ebenso wie C maschinennah und damit sehr schnell, schliesslich ist C++ ja auch mal aus C enstanden. Und: Auch in C++ kann optimiert programmiert werden.

    Das ist meine Antwort auf die ursprüngliche Frage.



  • Nur war die ursprüngliche Frage nicht "Warum programmiert ihr in C++?" sondern "Warum programmiert ihr in C?" Meine Antwort dazu:

    - kein unötiger Schnickschnack
    - ich kann C vollständig in relativ kurzer Zeit lernen
    - C Runtime unter Linux schneller als C++
    - Es gibt viel mehr C-Programmierer als C++ler
    - Programmfluß ist im Gegensatz zu C++ nachvollziehbar
    - Um Daten und Zugriffsfunktionen zusammenzufassen brauche ich keine Klassen in C.
    - Exceptions funktionieren in C++ nicht wirklich immer wie hier irgendwo im Forum schon von C++lern beschrieben wurde, also muss man eh was Eigenes schreiben oder eine Lib nutzen.

    Auf Deutsch wenn ich C++ programmieren muss könnt ich mir jedesmal den Finger in den Hals stecken.



  • lookwindows schrieb:

    Nur war die ursprüngliche Frage nicht "Warum programmiert ihr in C++?" sondern "Warum programmiert ihr in C?" Meine Antwort dazu:

    Falsch. Du antwortest auf "Welche Vorwände habt ihr euch zurechtgelegt, um zwar in C, aber nicht in C++ zu programmieren?"

    lookwindows schrieb:

    - kein unötiger Schnickschnack
    - ich kann C vollständig in relativ kurzer Zeit lernen
    - C Runtime unter Linux schneller als C++
    - Es gibt viel mehr C-Programmierer als C++ler
    - Programmfluß ist im Gegensatz zu C++ nachvollziehbar
    - Um Daten und Zugriffsfunktionen zusammenzufassen brauche ich keine Klassen in C.
    - Exceptions funktionieren in C++ nicht wirklich immer wie hier irgendwo im Forum schon von C++lern beschrieben wurde, also muss man eh was Eigenes schreiben oder eine Lib nutzen.

    Sehr vage ausgedrückt und meist in dem Maße falsch, wie es konkret wird oder objektiv erscheinen soll.

    lookwindows schrieb:

    Auf Deutsch wenn ich C++ programmieren muss könnt ich mir jedesmal den Finger in den Hals stecken.

    Ja, laß es doch dabei und versuche nicht, noch zu beweisen, warum du C++ nicht magst.

    Warum müßt ihr immer, statt einfach zu erklären, was Euch an C gefällt, eine kleine Haßtirade gegen C++ starten? Minderwertigkeiskomplexe?



  • Mit den "Haßtiraden" haben die C++ler angefangen ...

    Ist so wie in eine Motorradforum die Fragen nach dem richtigen Öl oder Zündkerzen.



  • Scheppertreiber schrieb:

    Mit den "Haßtiraden" haben die C++ler angefangen ...

    Lies nochmal genauer.
    Insbesondere die erste Seite und Didaktiker5s Eröffnung.



  • Ich mag das nicht nochmal alles lesen.

    Ich verwende C und nicht C++ und es wird erst einmal so bleiben.
    Die Gründe dafür ? Ich schätze mal 1 Jahr um es zu beurteilen.

    Ich lebe vom Programmieren und habe dieses Jahr nicht.

    Mag sein das Script-Kiddies die Zeit haben ... Ergebnisse ? Keiner
    hat hier mal aussagefähige Benchmarks oder so aufgeführt (da zähle
    ich auch die Entwicklungszeit hinzu).



  • Ich mag das nicht nochmal alles lesen.

    Du solltest nur die erste Seite lesen, da sie deine vorherige Aussage widerlegt.

    Ich lebe vom Programmieren und habe dieses Jahr nicht.

    Hier fehlt doch was.



  • lookwindows schrieb:

    Nur war die ursprüngliche Frage nicht "Warum programmiert ihr in C++?" sondern "Warum programmiert ihr in C?" Meine Antwort dazu:

    - kein unötiger Schnickschnack

    Definiere Schnickschnack.

    lookwindows schrieb:

    - ich kann C vollständig in relativ kurzer Zeit lernen

    Konnte ich bei C++ auch, ging schneller, als C zu lernen.

    lookwindows schrieb:

    - C Runtime unter Linux schneller als C++

    - Hab Windows, kann da keinen Unterschied feststellen, ob ich z.B. memmove nun unter C oder C++ aufrufe. Wenns da einen Unterschied gibt, sollte mal der entsprechende Compiler für Linux überarbeitet werden.

    lookwindows schrieb:

    - Es gibt viel mehr C-Programmierer als C++ler

    Historisch bedingt, C war vor C++ da, bei uns in der Firma gibts allerdings nur sehr wenige C und sehr viele C++ Programmierer, aber das kann man nicht verallgemeinern.

    lookwindows schrieb:

    - Programmfluß ist im Gegensatz zu C++ nachvollziehbar

    Schon klar, wenn man C++ nicht kann.
    [IRONIE]
    Ich kann kein F#, deshalb ist für mich der Programmfluss eines F# Programs nicht nachvollziehbar und somit ist F# schlecht.
    [/IRONIE]

    lookwindows schrieb:

    - Um Daten und Zugriffsfunktionen zusammenzufassen brauche ich keine Klassen in C.

    Klassen gibts in C ja auch gar nicht.

    lookwindows schrieb:

    - Exceptions funktionieren in C++ nicht wirklich immer wie hier irgendwo im Forum schon von C++lern beschrieben wurde, also muss man eh was Eigenes schreiben oder eine Lib nutzen.

    Ach nein, komisch, bei mir tun sie immer das, was sie sollen, vielleicht sitzt dann das Problem ja vor dem Monitor?

    lookwindows schrieb:

    Auf Deutsch wenn ich C++ programmieren muss könnt ich mir jedesmal den Finger in den Hals stecken.

    Jetzt hast du doch einen Grund für den Einsatz von C++, es sorgt bei dir immerhin für eine schlanke Figur. Meinen Glückwunsch.



  • Burkhi schrieb:

    lookwindows schrieb:

    - C Runtime unter Linux schneller als C++

    - Hab Windows, kann da keinen Unterschied feststellen, ob ich z.B. memmove nun unter C oder C++ aufrufe. Wenns da einen Unterschied gibt, sollte mal der entsprechende Compiler für Linux überarbeitet werden.

    memmove ist natürlich gleich. Ich weiß auch nicht, welche runtime da gemeint ist.



  • lookwindows schrieb:

    - Exceptions funktionieren in C++ nicht wirklich immer wie hier irgendwo im Forum schon von C++lern beschrieben wurde, also muss man eh was Eigenes schreiben oder eine Lib nutzen.

    Die gute Exception-Lib... 🙄


Anmelden zum Antworten