我们知道,使用string.Format方法可能会存在装箱的情况。比如如下:
static void Main(string[] args)
{
string s = string.Format("拼接{0}和{1}", 1, 2);
Console.WriteLine(s);
Console.ReadKey();
}
string.Format()方法接收的后两个形参类型是object,所以这里存在装箱。
现在查看IL代码:
→打开"开发人员命令提示"
→导航到应用程序所在的文件夹
→使用ildasm查看应用程序的il代码并输出到txt文件
→打开1.txt文本文件
→在IL代码中看到了2次装箱
如果在我们的应用程序中多次频繁地调用string.Format方法,比如记录日志,那么对值类型装箱发生了很多次,也意味着会产生很多次的内存分配,发生很多次的垃圾回收。
如何解决呢?
--用字符串拼接
修改代码如下:
static void Main(string[] args)
{
string s = "拼接" + 1.ToString() + "和" + 2.ToString();
Console.WriteLine(s);
Console.ReadKey();
}
我们看到,通过字符串拼接,避免了装箱的发生。