Java vs. C++
-
Java hat das Problem, dass final nicht const ist. Das stimmt. Insgesamt halte ich es aber für sicherer.
Zum Wrappen: Das habe ich später auch im Internet gelesen, aber dass ich dann Objekte auf dem Heap anlegen muss, ist auch nicht das Gelbe vom Ei.
Zu Qt: Ja, mag ein Problem von Qt sein, aber Qt macht C++ erst interessant. Crossplattform-Entwicklung macht man bei C++ mit Qt. Die Konkurrenz deckt bestenfalls eine Teilmenge von Qt ab. Qt bietet wirklich alle Standard-Techniken in einem Guss an.
-
ShadowClone schrieb:
Zum Wrappen: Das habe ich später auch im Internet gelesen, aber dass ich dann Objekte auf dem Heap anlegen muss, ist auch nicht das Gelbe vom Ei.
Demnach besteht Java nur aus Eiweiß.
-
floorball schrieb:
ShadowClone schrieb:
Zum Wrappen: Das habe ich später auch im Internet gelesen, aber dass ich dann Objekte auf dem Heap anlegen muss, ist auch nicht das Gelbe vom Ei.
Demnach besteht Java nur aus Eiweiß.
Größtenteils, ja. Und dank Qt, wird C++ auch zu einem Eiweiß-Klumpen, wenn man so vorgehen will, wie ich es oben beschrieben habe.
-
ShadowClone schrieb:
Zu Qt: Ja, mag ein Problem von Qt sein, aber Qt macht C++ erst interessant. Crossplattform-Entwicklung macht man bei C++ mit Qt. Die Konkurrenz deckt bestenfalls eine Teilmenge von Qt ab. Qt bietet wirklich alle Standard-Techniken in einem Guss an.
Meine Güte, wenn ich nur schon den Benutzernamen ShadowClone lese, dann weiß ich schon, dass da irgendein Stuss zu Qt kommt. Selbiges hier, genau so sehr fehl am Platz: https://www.c-plusplus.net/forum/p2512288#2512288
Was kommt als nächstes? LLVM, Root und Caffe sollte man von C++ komplett nach Java umschreiben, weil es für C++ kein Argument gibt, da diese Bibliotheken kein Qt benutzen?
-
ShadowClone schrieb:
Java hat das Problem, dass final nicht const ist.
Wieso ist das ein Problem?
-
Andromeda schrieb:
ShadowClone schrieb:
Java hat das Problem, dass final nicht const ist.
Wieso ist das ein Problem?
Weil sich das final bei Objekten nur auf die Referenz/Pointer bezieht und du die Member der Objekten immer noch manipulieren kannst. Das ist bei Klassen, die immutabel sein sollen bspw. ein Problem, da du nicht drum rumkommst ein Deep Copy zu machen, wenn du Parameter entgegen nimmst bzw. Member-Instanzen zurückgibst.
-
ShadowClone schrieb:
Andromeda schrieb:
ShadowClone schrieb:
Java hat das Problem, dass final nicht const ist.
Wieso ist das ein Problem?
Weil sich das final bei Objekten nur auf die Referenz/Pointer bezieht und du die Member der Objekten immer noch manipulieren kannst. Das ist bei Klassen, die immutabel sein sollen bspw. ein Problem, da du nicht drum rumkommst ein Deep Copy zu machen, wenn du Parameter entgegen nimmst bzw. Member-Instanzen zurückgibst.
Wenn eine Class immutabel sein soll, nennt man das final vor dem Schlüsselwort class!
-
Zeus schrieb:
ShadowClone schrieb:
Andromeda schrieb:
ShadowClone schrieb:
Java hat das Problem, dass final nicht const ist.
Wieso ist das ein Problem?
Weil sich das final bei Objekten nur auf die Referenz/Pointer bezieht und du die Member der Objekten immer noch manipulieren kannst. Das ist bei Klassen, die immutabel sein sollen bspw. ein Problem, da du nicht drum rumkommst ein Deep Copy zu machen, wenn du Parameter entgegen nimmst bzw. Member-Instanzen zurückgibst.
Wenn eine Class immutabel sein soll, nennt man das final vor dem Schlüsselwort class!
Ist in Java nicht so einfach.
https://docs.oracle.com/javase/tutorial/essential/concurrency/imstrat.html
-
Doch sehr einfach! Das Pattern ist so einfach zu verstehen wie C++ Const nicht transitiv ist.
-
Es ist aber nicht damit getan die Klasse final zu machen, wie von dir eingangs behauptet.
-
ShadowClone schrieb:
Es ist aber nicht damit getan die Klasse final zu machen, wie von dir eingangs behauptet.
Nein hab ich nie behauptet wo steht das?
-
Das ist mir jetzt echt zu doof.
-
eigentlich ist es ziemlich egal, welche programmiersprache du im endeffekt nimmst und es gibt auch kein besser. die "java-menschen" reden nur so schlecht über c++, weil sie eben zuerst java gelernt haben, und umgekehrt reden die "c++-menschen" so schlecht über über java, weil sie zuerst c++ gelernt haben, und beide haben dann so ihre gewohnheiten.
aber wie gesagt: im endeffekt ist es egal.
-
Quark. Ich hab zuerst C64-Basic gelernt und das werde ich hier sicher nicht als gut anpreisen.
-
und ich hab zuerst c gelernt und wollte es jetzt mal mit common lisp probieren, sofern ich die zeit dafür finde.
aber trotzdem bleibe ich dabei, dass zwischen c++ und java kein wirklich gravierender unterschied besteht, die leute aber wegen irgendwelcher, mehr oder weniger sinnfreier, sprachbestandteile und entsprechender gewohnheiten der meinung sind, dass die jeweils andere sprache schlechter ist.
-
HansKlaus schrieb:
aber trotzdem bleibe ich dabei, dass zwischen c++ und java kein wirklich gravierender unterschied besteht, die leute aber wegen irgendwelcher, mehr oder weniger sinnfreier, sprachbestandteile und entsprechender gewohnheiten der meinung sind, dass die jeweils andere sprache schlechter ist.
Das ist Quatsch. Die Syntax ist vll. ähnlich, aber Java kommt für verschiedene Anwendungsgebiete erst gar nicht in Betracht. Z. B. Treiber-, OS-Programmierung, Embedded auch eher ungeeignet, Real-Time, alles, was niedrigen Speicherverbrauch und wenig Latenz haben soll.
-
HansKlaus schrieb:
eigentlich ist es ziemlich egal, welche programmiersprache du im endeffekt nimmst und es gibt auch kein besser.
HansKlaus schrieb:
aber trotzdem bleibe ich dabei, dass zwischen c++ und java kein wirklich gravierender unterschied besteht, die leute aber wegen irgendwelcher, mehr oder weniger sinnfreier, sprachbestandteile und entsprechender gewohnheiten der meinung sind, dass die jeweils andere sprache schlechter ist.
Ach du lieber Himmel, du hast ja mal gar keine Ahnung.
-
Ja-Ne, deswegen gibt es auch JavaOS (https://en.wikipedia.org/wiki/JavaOS) und Java Embedded (http://www.oracle.com/technetwork/java/embedded/overview/index.html).
-
ShadowClone schrieb:
HansKlaus schrieb:
aber trotzdem bleibe ich dabei, dass zwischen c++ und java kein wirklich gravierender unterschied besteht, die leute aber wegen irgendwelcher, mehr oder weniger sinnfreier, sprachbestandteile und entsprechender gewohnheiten der meinung sind, dass die jeweils andere sprache schlechter ist.
Das ist Quatsch. Die Syntax ist vll. ähnlich, aber Java kommt für verschiedene Anwendungsgebiete erst gar nicht in Betracht. Z. B. Treiber-, OS-Programmierung, Embedded auch eher ungeeignet, Real-Time, alles, was niedrigen Speicherverbrauch und wenig Latenz haben soll.
Dafür würde ich spontan C verwenden und nicht C++
-
Zeus schrieb:
Ja-Ne, deswegen gibt es auch JavaOS (https://en.wikipedia.org/wiki/JavaOS) und Java Embedded (http://www.oracle.com/technetwork/java/embedded/overview/index.html).
Du kommst mir zunehmend vor wie ein Troll. Gehen tut vieles – gut, ist wieder eine andere Frage.
Ich kann auch ein Spiel 100% in Python schreiben, einen Browser auch – geht.