Convert.ToString
peut être utilisé pour convertir un nombre équivalent de la chaîne de la représentation dans une base spécifiée.
Exemple:
string binary = Convert.ToString(5, 2); // convert 5 to its binary representation
Console.WriteLine(binary); // prints 101
Cependant, comme souligné par les commentaires, Convert.ToString
prend uniquement en charge les éléments suivants limitée mais généralement suffisante - ensemble de bases: 2, 8, 10 ou 16.
Mise à jour (pour répondre à l'exigence de convertir à toute la base):
Je ne suis pas au courant de n'importe quelle méthode de la BCL qui est capable de convertir des nombres à toute la base de sorte que vous devez écrire votre propre fonction d'utilité. Un exemple simple serait ressembler à ça (notez que cela ne peut certainement être fait plus rapidement en remplacement de la concaténation de chaîne):
class Program
{
static void Main(string[] args)
{
// convert to binary
string binary = IntToString(42, new char[] { '0', '1' });
// convert to hexadecimal
string hex = IntToString(42,
new char[] { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
'A', 'B', 'C', 'D', 'E', 'F'});
// convert to sexagesimal
string xx = IntToString(42,
new char[] { '0','1','2','3','4','5','6','7','8','9',
'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z',
'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x'});
}
public static string IntToString(int value, char[] baseChars)
{
string result = string.Empty;
int targetBase = baseChars.Length;
do
{
result = baseChars[value % targetBase] + result;
value = value / targetBase;
}
while (value > 0);
return result;
}
/// <summary>
/// An optimized method using an array as buffer instead of
/// string concatenation. This is faster for return values having
/// a length > 1.
/// </summary>
public static string IntToStringFast(int value, char[] baseChars)
{
// 32 is the worst cast buffer size for base 2 and int.MaxValue
int i = 32;
char[] buffer = new char[i];
int targetBase= baseChars.Length;
do
{
buffer[--i] = baseChars[value % targetBase];
value = value / targetBase;
}
while (value > 0);
char[] result = new char[32 - i];
Array.Copy(buffer, i, result, 0, 32 - i);
return new string(result);
}
}
Mise À Jour 2 (Amélioration Du Rendement)
À l'aide d'une matrice de mémoire tampon au lieu de concaténation de chaîne à construire la chaîne de résultat donne une amélioration de la performance en particulier sur le grand nombre (voir méthode IntToStringFast
). Dans le meilleur des cas (c'est à dire la plus longue possible d'entrée) cette méthode est à peu près trois fois plus vite. Toutefois, pour les 1-chiffres (c'est à dire 1-chiffre dans la base cible), IntToString
sera plus rapide.