C++ vs. Java [Update]
-
Diese "absolute" Plattformunabhängigkeit würde ich dann aber doch gerne mal sehen...
Wie kommt es dann, daß unter Linux die Prioritäten meiner Threads nicht beachtet werden. Unter Windows aber schon (so wie man's eigentlich erwarten könnte).
Dafür weckt Windows einen Thread, der mit sleep schlafen gelegt wurde erst wieder auf, wenn er wirklich dran ist. Linux gibt ihm Rechenzeit sobald wie möglich, also egal, wie viele Threads warten, der aufgewachte kriegt sofort Rechenzeit.Fazit: Exaktes Timing unter Windows mit Prioritäten, exaktes Timing unter Linux mit sleep, wenn ich beide haben will muß ichs über Prioritäten und sleep lösen. Ist das nicht umständlich?
Deswegen war es zum Beispiel (mir) nicht möglich einen Thread-Dispatcher in Java zu schreiben, der ohne Mitarbeit der Threads funktionierte.Wo ist sie denn nun, diese Plattformunabhängigkeit? (ich mein natürlich die "absolute")
[ Dieser Beitrag wurde am 01.12.2002 um 12:31 Uhr von Jester editiert. ]
-
Original erstellt von volkard:
**
vielleicht glaubstes dem ja:
http://www.research.att.com/~bs/bs_faq.html#Java
**Da steht :
Java isn't platform independent; it is a platform. Like Windows, it is a proprietary commercial platform. That is, you can write programs for Windows/Intel or Java/JVM, and in each case you are writing code for a platform owned by a single corporation and tweaked for the commercial benefit of that corporation.
Gehen wir mal durch :
- Single Corporation : Unsinn. Es gibt nicht nur ne JVM von Sun. Es gibt z.B. auch JVMs von IBM oder von BEA. Zudem werden auch JVMs unter der GPL entwickelt. Z.B. Kaffe.
- "you can write programs for Windows/Intel or Java/JVM" : Unsinn. Normalerweise schreibt man Code für die JVM, weil das klug ist. Der Code läßt sich aber auch für andere Plattformen kompilieren. AFAIK kann man das z.B. mit dem GJC machen, oder? Außerdem gibt es Programme, wie "Excelsior Jet". Man kann sich aus Java-Code also auch ausführbare Dateien für andere Plattformen erzeugen. ...und dafür muss man NICHTS portieren, wie man es aus C++ kennt.
Java ist platformunabhängig. Allerdings wird aus Java-Code meistens Code für eine virtuelle Platform erzeugt. Die JVM. Das muss man aber nicht machen.
BTW : C++ ist nicht platformunabhängig, weil es keinen Compiler gibt, der C++-Code für die JVM kompiliert. :p Schonmal eine Platform, die häufig genutzt wird, auf der man mit C++ verloren hat. :p
[ Dieser Beitrag wurde am 01.12.2002 um 14:14 Uhr von Gregor editiert. ]
-
Original erstellt von volkard:
alles andere würde mir übrigens gestatten, so frei zu sein, die selbe "absolute plattformunabhängigkeit" für c++ zu postulierenTust du doch sowieso. Ich bin mir sicher, dass ich hier nen Thread finde, wenn ich suchen würde, in dem du sagst, dass C++ platformunabhängig ist, Java aber nicht.
Auch das ist natürlich Unsinn. In C++ sind ja sogar schon die Größen der primitiven Datentypen plattformabhängig. In Java nicht.
-
Original erstellt von Gregor:
Auch das ist natürlich Unsinn. In C++ sind ja sogar schon die Größen der primitiven Datentypen plattformabhängig. In Java nicht.Alle datentypen haben eine mindestgroesse!
Wenn eine Plattform diesen Datentyp groesser macht, um effektiver arbeiten zu koennen, dann darf sie das!wenn ich also nicht portieren will, dann nehme ich einfach die plattformspezifische groesse -> ansonsten verlasse ich mich nicht darauf.
dank typedefs kann man auch ueberall die selben datentypengroessen haben!
"you can write programs for Windows/Intel or Java/JVM" : Unsinn. Normalerweise schreibt man Code für die JVM, weil das klug ist.
Ob du das fuer klug haeltst oder nicht steht doch nicht zur debatte.
Java bzw. die JVM ist eine Plattform - daruber braucht man garnicht zu diskutieren!wann wirst du endlich begreifen, dass C++ einen anderen Ansatz der Plattformunabhaengigkeit hat?
Java verlangt eine VM
C++ einen CompilerBTW : C++ ist nicht platformunabhängig, weil es keinen Compiler gibt, der C++-Code für die JVM kompiliert. Schonmal eine Platform, die häufig genutzt wird, auf der man mit C++ verloren hat.
Was meinst du: gibt es mehr Plattformen mit einem C++ Compiler oder mit einer Java VM?
-
Original erstellt von Shade Of Mine:
**
Was meinst du: gibt es mehr Plattformen mit einem C++ Compiler oder mit einer Java VM?**Für C++ gibt es so gut, wie garkeinen standardkonformen Compiler. Wir haben ja letzt schon gesehen, dass es anscheinend Probleme macht, Programme zu schreiben, die auf mehreren Compilern kompilieren. In C++ gibt es also noch nichtmal Compilerunabhängigkeit. Wie soll der C++-Ansatz der Platformunabhängigkeit dann überhaupt funktionieren?
-
Original erstellt von Gregor:
Für C++ gibt es so gut, wie garkeinen standardkonformen Compiler. Wir haben ja letzt schon gesehen, dass es anscheinend Probleme macht, Programme zu schreiben, die auf mehreren Compilern kompilieren. In C++ gibt es also noch nichtmal Compilerunabhängigkeit. Wie soll der C++-Ansatz der Platformunabhängigkeit dann überhaupt funktionieren?Also mein aktuelles Projekt laeuft sowohl unter Unix mit gcc und icc sowie unter windows mit VC++ 6 und 7, sowie Borland C++ Compiler 5.5 (somit wahrscheinlich auch Borland C++ Builder 5 und 6) sowie gcc (mingw) und digital mars c++ compiler.
andere compiler habe ich nicht zum testen verwendet da ich sie nicht besitze - aber wie du siehst, scheint das ja ganz gut zu funktionieren!
Wenn ich dann noch threads und sockets einbauen werde, dann werde ich cross-plattform bibliotheken verwenden und somit auch Plattformunabhaengig (diesmal im Sinne von Java) zu sein.
Im Sinne von Java deswegen - weil ich auf meiner ziel Plattformeinfach eine implementierung der Runtime Library erwarte.
wenn man nicht aufpasst, dann kann es natuerlich schwer sein ein Programm zu portieren, aber ich denke, man kann in Java genauso sich auf eine Plattform festlegen und dann gezielt diese API nutzen...
ich kenn mich mit Java nicht aus, deshalb kann ich keine gegen Argumente bringen, aber deine contra C++ Argumente scheinen mir auch nicht gerade sehr stichhaltig!
-
@ Shade : Kann ja sein, dass du besonders gut plattformunabhängig und compilerunabhängig programmieren kannst. In diesem Thread sollte ein sehr kleines C++-Programm geschrieben werden, das wohl auch auf verschiedenen Plattformen kompiliert. Anscheinend ist da wohl doch schwerer als du es sagst. Oder willst du sagen, dass die Leute, die da die C++-Programme geschrieben haben, Idioten sind?
Bei Java nutzt man keine plattformspezifischen APIs. Man muss sich schon Mühe geben, damit ein Programm plattformabhängig wird.
-
Original erstellt von Gregor:
In diesem Thread sollte ein sehr kleines C++-Programm geschrieben werden, das wohl auch auf verschiedenen Plattformen kompiliert. Anscheinend ist da wohl doch schwerer als du es sagst. Oder willst du sagen, dass die Leute, die da die C++-Programme geschrieben haben, Idioten sind?um was gings da? Daß manche keine crossplatformlib für ne gute uhr finden? also die ACE-Wrappers haben ne Klasse ACE_High_Res_Timer dabei.
/** * @class ACE_High_Res_Timer * * @brief A high resolution timer class wrapper that encapsulates * OS-specific high-resolution timers, such as those found on * Solaris, AIX, Win32/Pentium, and VxWorks.
uder wars was anderes? hab nach 40 beiträgen aufgehört, den thread zu lesen.
-
Original erstellt von Gregor:
@ Shade : Kann ja sein, dass du besonders gut plattformunabhängig und compilerunabhängig programmieren kannst. In diesem Thread sollte ein sehr kleines C++-Programm geschrieben werden, das wohl auch auf verschiedenen Plattformen kompiliert. Anscheinend ist da wohl doch schwerer als du es sagst. Oder willst du sagen, dass die Leute, die da die C++-Programme geschrieben haben, Idioten sind?Der code von kingruedi ist ein POSIX kompatibler code -> das haette er natuerlich besser machen koennen um windows auch mit einzubeziehen.
der C++ standard garantiert zum zeitmessen nur clock() welches aber nicht sonderlich genau ist - deshalb hat kingruedi die posix funktion gettimeofday genommen, das gehoert natuerlich versteckt ->
long getMicroSeconds() { #ifdef __WIN32__ || WIN32 return GetTickCount(); #else timeval tv; timezone tz; gettimeofday(&tv,&tz); return tv.tv_usec; #endif }
und schon klappt es auch mit dem nachbarn!
alternativ kann man natuerlich crossplattform libraries verwendenBei Java nutzt man keine plattformspezifischen APIs. Man muss sich schon Mühe geben, damit ein Programm plattformabhängig wird.
Man kann mit C++ genauso plattformunabhaengige APIs verwenden, man muss aber nicht.
-
Ja mai, was muss man sich bei C++ für eine Mühe machen, seinen Code plattformunabhängig zu halten? Was ist, wenn jemand getTickCount() oder die Posix-Variante nicht kennt? Und bei den Bibliotheken, die es für versch. Betriebssysteme gibt, aht man auch so seine Probleme. Ich kann z.B.kein Qt mit dem icc kompilieren, weil in den Headern ständig so sachen wie typedef int bool; stehen. Das kompiliert der icc beispielsweise nicht.
-
Original erstellt von Doktor Prokt:
Was ist, wenn jemand getTickCount() oder die Posix-Variante nicht kennt?und wenn die cross-platform-lib das nicht anbietet? dann ist er angeschmiert und muß googlen oder hier fragen.
ist bei java natürlich leichter. das, was java anbietet, sieht überall sehr ähnlich aus. natürlich ist die panik größer, wenn mal was nicht angeboten wird.
so hat halt alles seine vor- und nachteile.
-
Original erstellt von Gregor:
Bei Java nutzt man keine plattformspezifischen APIs.Ach? <ironie>Wie misst den so ein Java-System die Zeit ohne Uhr? Ich vergas: In Java haben wir ja per Definition eine Internetverbindung mit der wir, in Echtzeit, von der Sun-Seite die vergangene Zeit, in Planck-Zeit, seit der Erfindung Javas laden können. Oder hatten wir immer eine Uhr?</ironie>
Man muss sich schon Mühe geben, damit ein Programm plattformabhängig wird.
Jedes Programm hängt von einer Plattform ab. Siehe oben.
Original erstellt von Doktor Prokt:
Ich kann z.B.kein Qt mit dem icc kompilierenQT ist IMHO auch ein schönes Beispiel wie C++ nicht aussehen sollte. Dann kann man ja gleich Java nehmen :).
PS: Mein Pascal-Compiler compilert meinen C-Code nicht. C kann nicht plattformunabhängig sein.
-
Ich möchte nur eines loswerden:
könnt ihr nicht mal damit aufhören euch wie in der Grundschule darüber zu streiten welches Matchbox-Auto das bessere ist???Wer in Java programmieren will/ muss, soll das tun.
Wer hingegen C++ besser findet, ist ja auch keine Schande.
Nur darüber zu streiten was besser ist, ist einfach nur unsinnig.
-
Mir kam es eigentlich mehr auf diesen anderen Fehler an, nicht das mit der Zeit:
Benchmark.cpp:38: use of 'less' is ambiguous;
Benchmark.cpp:12: first declared as 'int less(const void*, const void*)' here c:/c++/mingw/ include/c++/3.2/bits/stl_function.h:195: also declared as 'template<class _Tp> struct std::less' here[ Dieser Beitrag wurde am 01.12.2002 um 17:32 Uhr von Gregor editiert. ]
-
Original erstellt von Shade Of Mine:
**
Der code von kingruedi ist ein POSIX kompatibler code -> das haette er natuerlich besser machen koennen um windows auch mit einzubeziehen.
**Ehrlich gesagt interessiert es mich garnicht, zu was der Code alles kompatibel ist. Das, worauf es mir ankam ist, dass erst das 4. Programm mit g++ kompilierbar war. Ganz schön schwach, wenn C++-Programme doch auf allen möglichen Compilern kompiliert werden sollen, um Plattformunabhängigkeit zu erreichen.
-
Ach? <ironie>Wie misst den so ein Java-System die Zeit ohne Uhr? Ich vergas: In Java haben wir ja per Definition eine Internetverbindung mit der wir, in Echtzeit, von der Sun-Seite die vergangene Zeit, in Planck-Zeit, seit der Erfindung Javas laden können. Oder hatten wir immer eine Uhr?</ironie>
Nein! Das wird wohl mit nem Wrapper gelöst. Sowas, wie
long getMicroSeconds() { #ifdef __WIN32__ || WIN32 return GetTickCount(); #else timeval tv; timezone tz; gettimeofday(&tv,&tz); return tv.tv_usec; #endif }
wohl. Allerdings vom Compiler bzw. von der JVM aus.
Jedes Programm hängt von einer Plattform ab. Siehe oben.
Nein. Das tut es nicht. Es kommt drauf an, wie abstrakt die Programmiersprache gehalten ist. Also wie stark diese von einer gegebenen Platform abstrahiert.
[ Dieser Beitrag wurde am 01.12.2002 um 19:00 Uhr von Gregor editiert. ]
-
Original erstellt von Gregor:
[quote]Original erstellt von Shade Of Mine:
Ehrlich gesagt interessiert es mich garnicht, zu was der Code alles kompatibel ist. Das, worauf es mir ankam ist, dass erst das 4. Programm mit g++ kompilierbar war. Ganz schön schwach, wenn C++-Programme doch auf allen möglichen Compilern kompiliert werden sollen, um Plattformunabhängigkeit zu erreichen.du musst mal von diesem Java ist das einzig wahre Trip runter kommen.
POSIX ist eine Standard. Wer sich nach diesem Standard richtet, kann seine Programme auf allen POSIX kompatiblen Systemen laufen lassen!kingruedi hat mit less einen Fehler gemacht - das ist der Grund warum man using namespace std; nicht verwenden sollte! (less ist nähmlich im Standard schon definiert)
Wenn du keine solchen #ifdef konstrukte in C++ haben willst, nimmst du einfach eine Plattformunabhängige Library! (die versteckt das ganze vor dir, genau so wie deine VM)
was stoert dich an dem C++ konzept der PLattformunabhänigkeit? Es hat bis jetzt bestens funktioniert - und wird auch noch weiterhin funktionieren. Egal ob du es magst oder nicht, aber es ist und bleibt ein Ansatz der Plattformunabhänigkeit, genauso wie der Java Ansatz: Java als eine Plattform zu nehmen.
-
Original erstellt von Shade Of Mine:
**du musst mal von diesem Java ist das einzig wahre Trip runter kommen....
was stoert dich an dem C++ konzept der PLattformunabhänigkeit? Es hat bis jetzt bestens funktioniert - und wird auch noch weiterhin funktionieren. Egal ob du es magst oder nicht, aber es ist und bleibt ein Ansatz der Plattformunabhänigkeit, genauso wie der Java Ansatz: Java als eine Plattform zu nehmen.**
Ich glaube, du machst es dir zu einfach! Ich bin nicht auf nem Java-Trip! :p Momentan bin ich dabei, ganz massiv C++ zu lernen. ...und zwar aus guten Gründen. C++ hat ne Menge Stärken. Zum Beispiel die Geschwindigkeit oder die Möglichkeit, systemnah programmieren zu können. IMHO ist Platformunabhängigkeit aber keine Stärke von C++. Da kommt es mir so vor, als ob hier einige andere ziemlich stark auf nem C++-Trip sind und sich die Sprache schöner reden als sie ist.
-
Original erstellt von Gregor:
Da kommt es mir so vor, als ob hier einige andere ziemlich stark auf nem C++-Trip sind und sich die Sprache schöner reden als sie ist.zum teil ja, aber du musst bedenken das Shade Of Mine kein durchschnitts Programmierer ist,
-
Original erstellt von Gregor:
[QBIMHO ist Platformunabhängigkeit aber keine Stärke von C++[/QB]Eine stärke wahrscheinlich nicht, da man schon ordentlich programmieren muss um Plattformunabhänig zu bleiben. Allerdings ist das möglich.
Der Ansatz ist nicht so komfortabel wie bei Java (es sei denn man macht es wie Java -> zB cygwin.dll ist eine POSIX Umgebung unter Windows, das ist wie die VM, die ist ja eine Java umgebung).
aber C++ ist dennoch Plattformunabhänig, sonst gäbe es ja wohl keine Crossplattformprogramme ala Mozilla, OpenOffice,...