转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 站长学院 >> Web开发 >> 正文
三种方法讲解Asp.net字符串连接运算的效率问题         ★★★★

三种方法讲解Asp.net字符串连接运算的效率问题

作者:闵涛 文章来源:闵涛的学习笔记 点击数:1312 更新时间:2009/6/9 2:33:20

using System;  
 
using System.Text;  
 
namespace ConsoleApplication1  
 
{  
 
    class Program  
 
    {  
 
        private const int loopTimes = 10000;  
 
        static void Main(string[] args)  
 
        {  
 
            string str = string.Empty;  
 
            string str1 = string.Empty;  
 
            StringBuilder sb = new StringBuilder();  
 
            DateTime timeStart = DateTime.Now;  
 
            for (int i = 0; i < loopTimes; i++)  
 
            {  
 
                str += i.ToString();  
 
                str += i.ToString();  
 
                str += i.ToString();  
 
            }  
 
            Console.WriteLine(string.Format("字符串直接做加法运行{0}次的时间是:{1}", loopTimes, DateTime.Now.Subtract(timeStart)));  
 
            timeStart = DateTime.Now;  
 
            for (int i = 0; i < loopTimes; i++)  
 
            {  
 
                str1 += string.Format("{0}{1}{2}", i, i, i);  
 
            }  
 
            Console.WriteLine(string.Format("字符串format运行{0}次的时间是:{1}", loopTimes, DateTime.Now.Subtract(timeStart)));  
 
            timeStart = DateTime.Now;  
 
            for (int i = 0; i < loopTimes; i++)  
 
            {  
 
                sb.Append(i);  
 
                sb.Append(i);  
 
                sb.Append(i);  
 
            }  
 
            Console.WriteLine(string.Format("stringbuilder运行{0}次的时间是:{1}", loopTimes, DateTime.Now.Subtract(timeStart)));  
 
        }  
 
    }  
 
}  
  字符串直接做加法运行10000次的时间是:00:00:03.8262385 字符串format运行10000次的时间是:00:00:01.3118532 stringbuilder运行10000次的时间是:00:00:00.0156173

  字符串直接做加法运行20000次的时间是:00:00:20.9584166 字符串format运行20000次的时间是:00:00:06.9028466 stringbuilder运行20000次的时间是:00:00:00.0312346

  从上面的两次循环可以看出来

  字符串直接做加法:相当于2的n次方(每一次加法都会留下一个副本) 字符串format:相当于(2的n次方)/X (X >= 1 && X <=3) (format方法每次只留下一个副本,不管里面有几个参数 .  注 :  最多只能有3个参数) stringbuilder:相当于n * 2(从始至终都只有本身)

  看了上面稍微业余点的说明,相信大家明白了为什么技术主管在抽查代码的时候,看到一堆的字符串加法会火冒三丈了吧.(而且这些副本的销毁是有GC控制的,时间不能确定,所以短时间进行了海量的字符串加法运算,内存会爆掉的.).所以技术主管骂人也就可以理解了:  一方面是效率问题,令一方面是内存消耗.在此之外技术主管也看到了你本身的令一个问题:你根本就是一个垃圾代码的制造者!

  结论:如果是少量的加法运算,可以使用String.Format().如果是类似循环的加法运算,别想了肯定是StringBuilder.Append()


[视音频技术]电信座机(电话机)设置黑名单的方法(拦截骚扰电…  [C语言系列]C#中webBrowser控件屏蔽脚本错误提示方法
[办公软件]设置Word2003文档密码方法详解  [电脑应用]WordPress使用wp-postviews统计文章浏览次数(点击…
[Web开发]dede 调用自定义字段方法详解  [C语言系列]C#中combobox 控件属性、事件、方法(部分常用)
[Web开发]PHP判断文件是否存在的方法  [Web开发]php使用$_GET获取信息为空时使其不报错的方法
[Web开发]ASP生成Word文档的方法  [Web开发]用asp生成word文档打印的方法
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Web开发  · 网页制作
    · 平面设计  · 网站运营
    · 网站推广  · 搜索优化
    · 建站心得  · 站长故事
    · 互联动态
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台