如何在c#中将int数据类型转换为字符串数据类型?


string myString = myInt.ToString();

int num = 10;
string str = Convert.ToString(num);

任何对象的ToString方法都应该返回该对象的字符串表示形式。

int var1 = 2;

string var2 = var1.ToString();

or:

string s = Convert.ToString(num);

string a = i.ToString();
string b = Convert.ToString(i);
string c = string.Format("{0}", i);
string d = $"{i}";
string e = "" + i;
string f = string.Empty + i;
string g = new StringBuilder().Append(i).ToString();

string str = intVar.ToString();

在某些情况下,您不必使用ToString()

string str = "hi " + intVar;

继续讨论@Xavier的回答,这里有一个页面,可以快速比较几种不同的方法,从100次迭代到21,474,836次迭代。

这似乎是一个平局:

int someInt = 0;
someInt.ToString(); //this was fastest half the time
//and
Convert.ToString(someInt); //this was the fastest the other half the time

using System.ComponentModel;

TypeConverter converter = TypeDescriptor.GetConverter(typeof(int));
string s = (string)converter.ConvertTo(i, typeof(string));

以防你想要二进制表示,而你还在昨晚的派对上喝得酩酊大醉:

private static string ByteToString(int value)
{
    StringBuilder builder = new StringBuilder(sizeof(byte) * 8);
    BitArray[] bitArrays = BitConverter.GetBytes(value).Reverse().Select(b => new BitArray(new []{b})).ToArray();
    foreach (bool bit in bitArrays.SelectMany(bitArray => bitArray.Cast<bool>().Reverse()))
    {
        builder.Append(bit ? '1' : '0');
    }
    return builder.ToString();
}

注意:关于不能很好地处理字节顺序……


如果你不介意为了速度而牺牲一点内存,你可以使用下面的方法生成一个预先计算字符串值的数组:

static void OutputIntegerStringRepresentations()
{
    Console.WriteLine("private static string[] integerAsDecimal = new [] {");
    for (int i = int.MinValue; i < int.MaxValue; i++)
    {
        Console.WriteLine("\t\"{0}\",", i);
    }
    Console.WriteLine("\t\"{0}\"", int.MaxValue);
    Console.WriteLine("}");
}

没有一个回答提到ToString()方法可以应用于整数表达式

Debug.Assert((1000*1000).ToString()=="1000000");

甚至是整型字面量

Debug.Assert(256.ToString("X")=="100");

虽然像这样的整数字面值通常被认为是糟糕的编码风格(魔术数字),但在某些情况下,这个特性是有用的…


string s = "" + 2;

你可以做一些好事,比如:

string s = 2 + 2 + "you" 

结果将是:

“你”


如果你从数据集中

string newbranchcode = (Convert.ToInt32(ds.Tables[0].Rows[0]["MAX(BRANCH_CODE)"]) ).ToString();