Int zu char Array
-
Hallo,
kennt wer denn Code um eine int Variable zu char Arrays zumachen?
-
Falls du einen
intin einen String schreiben willst: Dazu gibt es hier einen FAQ-Eintrag.Der Beispielcode für C++11 ist
// int -> string { int const i = 10; string s = to_string(i); cout << s << endl; }Ansonsten musst du dich etwas klarer ausdrücken, deine Frage ist ziemlich mehrdeutig.
Edit: Da du ja explizit nach**
char-Arrays** fragst: Mittels der Methodec_str()bekommt man einen nullterminierten C-String welcher den gleichen Inhalt hat wie dasstring-Objekt.Falls du ein modifizierbares
char-Array haben willst, kannst du auch das&str[0]-Idiom verwenden. Und falls du tatsächlich ein echteschar-Arrayobjekt brauchst, definiere selbiges und nutzesnprintfum die Zahl hineinzuschreiben.
-
ich glaube er hat z.b. ein 32 bit integer und will daraus ein char[4] machen um z.b. die einzelnen bytewerte zu verarbeiten... Jedenfalls würde ich das draus interpretieren
-
Genau das meine ich
-
interpreta schrieb:
ich glaube er hat z.b. ein 32 bit integer und will daraus ein char[4] machen um z.b. die einzelnen bytewerte zu verarbeiten... Jedenfalls würde ich das draus interpretieren
memcpydürfte reichen:int i = 2234; unsigned char arr[sizeof(int)]; std::memcpy(arr, &i, sizeof(arr)); // benötigt <cstring>Natürlich ist es auch möglich Bitshifts zu verwenden:
int i = 2234; unsigned char arr[sizeof(int)]; // Die Schleife wird vom Compiler geunrolled. for( unsigned c = 0; c != sizeof(arr); ++c ) arr[c] = i >> c*CHAR_BIT; // benötigt <climits>
-
Oder einfach casten und direkt auf dem Original arbeiten?
int foo = 7; reinterpret_cast<char*>(&foo)[0]=9; cout << foo;
-
Ich schließe die Frage gleich mal an:
Union böse oder gangbar?template <typename T> // hier evtl nur fundamentaltypen zulassen union Serializer { T value; char [sizeof(T)] data; };
-
Tim06TR schrieb:
Ich schließe die Frage gleich mal an:
Union böse oder gangbar?Ein Klugscheißer würde einwenden, dass es undefiniertes Verhalten ist. Ich würde daraufhin einwenden, dass es in jeder bekannten Implementierung wie gewünscht funktioniert und daher eine gute Methode ist.
-
SeppJ schrieb:
Oder einfach casten und direkt auf dem Original arbeiten?
int foo = 7; reinterpret_cast<char*>(&foo)[0]=9; cout << foo;Das versteh ich nicht ganz... warum [0]=9?
-
Warum nicht? Ist doch nur ein Beispiel.
-
Ein Klugscheißer würde einwenden, dass es undefiniertes Verhalten ist.
Warum?
-
Arcoth schrieb:
Ein Klugscheißer würde einwenden, dass es undefiniertes Verhalten ist.
Warum?
Wenn ich das nicht falsch verstanden habe, dann dürfte das 9.5.1 sein:
§9.5.1 schrieb:
In a union, at most one of the non-static data members can be active at any time, that is, the value of at most one of the non-static data members can be stored in a union at any time.
-
Übersetzt also in etwa:
In einem Union darf nur auf das zuletzt beschriebene Member lesend zugegriffen werden.
-
Th69 schrieb:
Übersetzt also in etwa:
In einem Union darf nur auf das zuletzt beschriebene Member lesend zugegriffen werden.Das steht dort nicht (oder jedenfalls kann diese Überstzung leicht missverstanden werden). Dort steht nur, dass wenn auf diesen Speicherbereich zugegriffen wird, der gelesene Zustand derjenige ist, der zum zuletzt beschriebenen (=aktiven) Member gehört. Ob dieser Zugriff legal ist oder nicht, wird in diesem Absatz überhaupt nicht diskutiert - dafür empfiehlt ein Blick in 3.10/10. Der Absatz ist deswegen nicht überflüssig: ohne diese Klarstellung wäre nämlich nicht klar, auf welchen gespeicherten Typ sich 3.10/10 beziehen soll.
-
In einem Union darf nur auf das zuletzt beschriebene Member lesend zugegriffen werden.
Falsch. Wo steht etwas von lesen?
Der entscheidende Teil des Standards der es nämlich zu erlauben scheint ist strict aliasing.
§3.10/10 schrieb:
If a program attempts to access the stored value of an object through a glvalue of other than one of the following types the behavior is undefined:
— a char or unsigned char type.Ich frage mich dennoch ob die Zeigerarithmetik definiert ist, da doch kein Arrayobjekt existiert...
Ich würde daraufhin einwenden, dass es in jeder bekannten Implementierung wie gewünscht funktioniert
GCC kann hier durchaus gruselige Optimierungen durchführen.
Edit: Zu spät.
-
btw,
SeppJ schrieb:
Oder einfach casten und direkt auf dem Original arbeiten?
int foo = 7; reinterpret_cast<char*>(&foo)[0]=9; cout << foo;keiner hier mag Referenzcasts?
int foo = 42; auto& foo_as_chars = reinterpret_cast<char(&)[]>(foo);finde ich viel sprechender in Hinblick auf das, was im Anschluss damit gemacht wird.
-
camper schrieb:
btw,
SeppJ schrieb:
Oder einfach casten und direkt auf dem Original arbeiten?
int foo = 7; reinterpret_cast<char*>(&foo)[0]=9; cout << foo;keiner hier mag Referenzcasts?
int foo = 42; auto& foo_as_chars = reinterpret_cast<char(&)[]>(foo);finde ich viel sprechender in Hinblick auf das, was im Anschluss damit gemacht wird.
Seit wann gibts es denn Referenzen auf Arrays of unknown Bound? Kann man die ueberhaupt irgendwie gueltig initialisieren, mal abgesehen von Casts?
-
Kellerautomat schrieb:
Seit wann gibts es denn Referenzen auf Arrays of unknown Bound? Kann man die ueberhaupt irgendwie gueltig initialisieren, mal abgesehen von Casts?
Schon immer. Genauso wie du z.B. Referenzen auf noch nicht definierte Klassen haben kannst.
extern int array[]; int (&ref)[] = array; int array[4]; // decltype(ref) ist immer noch int(&)[] - der referenzierte Typ wird also nicht nachträglich vollständig
-
Ich habe auch eine solche extern-Deklaration ohne Bounds noch nie gesehen. Hat das Ganze irgendeinen praktischen Nutzen?
-
Kellerautomat schrieb:
Ich habe auch eine solche extern-Deklaration ohne Bounds noch nie gesehen. Hat das Ganze irgendeinen praktischen Nutzen?
Du kannst stehts ein array-to-pointer decay durchfüren und den Zeiger auf das erste Element erhalten. Damit kannst du auch direkt auf die Arrayelemente per Subscript-Operator zugreifen:
extern int arr[]; arr[5] = 3;Gibt dir zwar ggf. einen Linker-, nicht aber einen Compilerfehler. Du kannst also (teilweise eingeschränkt) damit arbeiten.
Das Ganze könnte vielleicht nützlich werden wenn du von ÜE A auf ein Array in ÜE B zugreifen willst, aber unabhängig von der genauen Größe bleiben willst. Einen konkreten Anwendungsfall kenne ich nicht.