Alternative zu C,C++
-
Nimm D
-
;fricky schrieb:
gary1195 schrieb:
kennt jemand eine gute alternative zu c c++.
zu c++ gibts viele gute alternativen, zu C schon weniger.
falsch. statt c kann man stets einen besseren makro-assembler nehmen; da gibt es keinen merklichen unterschied.
-
Oder nimm Rebol, mal was anderes
-
volkard schrieb:
;fricky schrieb:
gary1195 schrieb:
kennt jemand eine gute alternative zu c c++.
zu c++ gibts viele gute alternativen, zu C schon weniger.
falsch. statt c kann man stets einen besseren makro-assembler nehmen; da gibt es keinen merklichen unterschied.
C ist *der* makroassembler schlechthin, sogar portabel.
-
Basher!=basher...irgendwann bringt ihr mich noch ins Grab, Jungs.
-
Haskell Scheme ML
-
;fricky schrieb:
gary1195 schrieb:
kennt jemand eine gute alternative zu c c++.
zu c++ gibts viele gute alternativen, zu C schon weniger. aber wie schon einer hier schrieb: was hast du vor?
Wieso wusste ich schon als ic den Titel gelesen hab dass hier wieder sowas kommt? Der Thread wird sicherlich wieder die übliche Endlosdiskussion, wo vermutlich der OP schon jetzt garnicht mehr mitliest.
C ist die beste Sprache von Welt
-
pumuckl schrieb:
Wieso wusste ich schon als ic den Titel gelesen hab dass hier wieder sowas kommt? Der Thread wird sicherlich wieder die übliche Endlosdiskussion, wo vermutlich der OP schon jetzt garnicht mehr mitliest.
wenn der OP mal sagen würde was er programmieren will, dann könnten wir auch konkreter werden.
-
Basher schrieb:
pumuckl schrieb:
Wieso wusste ich schon als ic den Titel gelesen hab dass hier wieder sowas kommt? Der Thread wird sicherlich wieder die übliche Endlosdiskussion, wo vermutlich der OP schon jetzt garnicht mehr mitliest.
wenn der OP mal sagen würde was er programmieren will, dann könnten wir auch konkreter werden.
Äh, fricky? Hast du es wirklich getan?
-
Basher schrieb:
C ist *der* makroassembler schlechthin, sogar portabel.
na, nun übertreib' mal nicht
-
Nimm asm. Weil, darüber hab ich mal ne halbe Seite gelesen. Damit kann man push und pop machen.
-
u-ser_l schrieb:
Basher schrieb:
C ist *der* makroassembler schlechthin, sogar portabel.
na, nun übertreib' mal nicht
C ist doch portabel.
Naja, sagen wir mal ziemlich portabel, solange man damit nicht direkt an die Hardware geht. Aber andererseits: C zu nehmen, wenn damit nicht direkt an die Hardware gehen will, wäre furchtbar ungeschickt. Damit gibt es keine Anwendungsfälle, wo die "Portabilität" von C einen Vorteil bieten würde.
-
volkard schrieb:
u-ser_l schrieb:
Basher schrieb:
C ist *der* makroassembler schlechthin, sogar portabel.
na, nun übertreib' mal nicht
C ist doch portabel.
Naja, sagen wir mal ziemlich portabel, solange man damit nicht direkt an die Hardware geht. Aber andererseits: C zu nehmen, wenn damit nicht direkt an die Hardware gehen will, wäre furchtbar ungeschickt. Damit gibt es keine Anwendungsfälle, wo die "Portabilität" von C einen Vorteil bieten würde.Außer in Fällen wo Portabilität Verfügbarkeit eines Compilers ist
-
gary1195 schrieb:
Eigentlich würde ich gerne Programm einfach mal schreiben anstatt mich dauernd nur mit dem compiler rumschlagen zu müssen.
Die Alternative ist ein Buch. Nämlich ein gutes C++-Buch, womit Du C++ lernen kannst. Ich programmiere täglich mit C++ und schlage mich nicht mit dem Compiler rum.
-
volkard schrieb:
C ist doch portabel.
Naja, sagen wir mal ziemlich portabel, solange man damit nicht direkt an die Hardware geht.nehmen wir an, du hast 'ne hardwarekomponente, die einen treiber braucht, der zuerst mal auf host-controller X laufen soll. machste den treiber in C, dann kannste, wenn du gut programmiert hast, ihn später ohne probleme nach host-controller Y portieren. programmierst du den treiber aber in assembler und X hat 'nen anderen CPU-core als Y, dann hast du die pappnase auf. oder schaut euch mal linux an, das läuft auf den verschiedensten architekturen. warum? das zauberwort lautet: C
-
ja, wenn man die nicht-portablen Sprachelemente einfach nicht benutzt, kann man wohl in jeder Sprache 'portabel' programmieren.
Daß man in C portabel programmieren kann, bestreitet niemand.
Neulich mußte ich ein C/C++ source-Paket installieren, dessen configure war satte ~15500 Zeilen lang, und selbst da war Nacharbeit am Code angesagt, weil irgendwelche impliziten includes seit Version 4.xx nicht so included werden, wie es die configure für Version 4.yy erwartet
Ein n-teiliges System bietet O(n^2) Möglichkeiten für gegenseitige Abhängigkeiten. Je größer n ...
'Portabel' + 'hardwarenah' sind zwei einander widerstrebende Ziele und schließen sich daher gegenseitig aus. Kompromisse zugunsten der einen oder der anderen Seite sind selbstmurmelnd möglich.
'hardware'-nah an einer virtuellen Maschine geht natürlich immer, so weit war man aber schon vor Jahrzehnten -> Websuche nach Cintpos.
ich will nicht sagen, daß der Ansatz von hardwarenaher + portabler Programmierung mit C/C++ gescheitert ist, aber es scheint zumindest zunehmend mühsam zu werden, wohl auch wegen der zunehmenden Zahl an Abhängigkeiten von Libraries, die ihrerseits von weiteren Libraries abhängen können usw. -
-
gary1195 schrieb:
Eigentlich würde ich gerne Programm einfach mal schreiben anstatt mich dauernd nur mit dem compiler rumschlagen zu müssen.
Mach keine Fehler, dann hattu keinen Stress mit dem Compiler. Selbst bei Visual Basic wirst du vermutlich das gleiche Problem haben wie jetzt.
Was meinst du mit 'rumschlagen', das der Compiler sich bei jeder zweiten Zeile wegen nem Syntaxfehler anpisst?
Das ist normal.
-
PCTT
ist ne tolle Programmiersprache. Ich meine mich zu erinnern, dass das für "Please close this thread" steht.
-
u-ser_l schrieb:
'Portabel' + 'hardwarenah' sind zwei einander widerstrebende Ziele und schließen sich daher gegenseitig aus.
nee, das stimmt nicht. wenn ich z.b. in C auf irgendwelche register eines chips zugreifen will (über memory mapped I/O):
#define BASE 0x1000 uint8_t *reg1 = (uint8_t*)BASE + 0; uint8_t *reg2 = (uint8_t*)BASE + 1; uint8_t *reg3 = (uint8_t*)BASE + 2;
^^dann passt es immer, egal wo. ich muss nur BASE einmal pro host-system anpassen und sämtlicher anderer code, der mit dieser hardware arbeitet (z.b. ein sehr komplexer treiber), muss nicht verändert werden.
-
Basher schrieb:
u-ser_l schrieb:
'Portabel' + 'hardwarenah' sind zwei einander widerstrebende Ziele und schließen sich daher gegenseitig aus.
nee, das stimmt nicht. wenn ich z.b. in C auf irgendwelche register eines chips zugreifen will (über memory mapped I/O):
#define BASE 0x1000 uint8_t *reg1 = (uint8_t*)BASE + 0; uint8_t *reg2 = (uint8_t*)BASE + 1; uint8_t *reg3 = (uint8_t*)BASE + 2;
^^dann passt es immer, egal wo. ich muss nur BASE einmal pro host-system anpassen und sämtlicher anderer code, der mit dieser hardware arbeitet (z.b. ein sehr komplexer treiber), muss nicht verändert werden.
Falsch, auf Systemen ohne MMIO fällst du damit dick auf die Fresse. Portabel wäre es den Zugriff zu abstrahieren.