Hi!
Eines gleich vorab: Wie das ganze prinzipiell funktioniert weiß ich - also von Binär nach Dezimal, nur in dieser Größenordnung nicht
Ich möchte mir eine eigene Bibliothek schreiben, mit deren Hilfe man unendlich große Ganzzahlen und beliebig genaue (und endlos große) Dezimalzahlen darstellen und mit ihnen auch rechnen kann. Ich glaube, jemand anderer hier macht das selbe auch gerade, nur benötige ich es in C# und möchte es des Lernwertes wegen selbst machen!
Nun habe ich mir überlegt, die Daten intern in einem Byte-Array zu speichern und mit diesem dann die Rechenoperationen durchzuführen, was an sich kein allzu großes Problem sein sollte (zumindestens die vier Grundrechnungsarten). Jedenfalls habe ich keine Idee, wie ich dieses Byte-Array in eine Zeichenkette umwandeln kann! Solange das ganze den Integer bzw. Int64 Bereich nicht sprengt, ist das natürlich nicht sehr schwer, doch wenn die internen Datentypen nicht mehr ausreichen, dann weiß ich nicht mehr weiter.
Vom Prinzip her müsste ich ja lediglich den Zahlenwert mit 256 hoch dem Stellenwert multiplizieren und die Summe der Ergebnisse wäre die endgültige Zahl.
Code:
byte[] data = /* something */;
/* datatype */ number = 0;
for (int i = 0; i < data.Length; i++)
number += data[i] * Math.Pow(256, i);
string num = Convert.ToString(number);
Die Umwandlung wäre auch nicht schwer, wenn die Basis des Dezimalsystems (also 10) ein Hochfaches (nicht Vielfaches ^^) von 2 wäre, so wie Octal (Basis 8, je 3 Bit pro Ziffer) oder Hexadezimal (Basis 16, je 4 Bit pro Ziffer/Zeichen).
Könnt ihr mit hilfreiche Tipps oder Links dazu geben bzw. habt ihr selbst Ideen, wie ich das am besten bewerkstellige?
Lg oli
[edit] Meine Frage richtet sich natürlich auch auf die Umwandlung von einer Zeichenkette zu einem Byte-Array