首页 > 编程 > .NET > 正文

如何最大限度提高.NET的性能 (续)

2024-07-10 13:09:14
字体:
来源:转载
供稿:网友

   昨天发了一篇如何最大限度提高.net性能的文章,评论的人不少,在这里非常感谢大家的评论,其中有些是指出文章的一些错误的,在这里感谢那些耐心写评论的老大们,小弟受益不少。
  
   昨天那篇主要是从写代码的一些细节上来提高速度,可能很些是难实际感受到性能的提高,但是作为一名程序员,不断提高自己代码的质量是不断追求的目标。
  
   其实随着硬件的发展,现在硬件的速度已经远远满足大多数人的的需要了,甚至有些人提出算法在现在软件开发中越来越不起作用了。记得以前看过麻省的数据结构视频,讲课的教授就问过一个问题(我记得不大清楚了,他的大概意思就是这样):既然算法现在变得不重要了,为什么我们还要在这里研究呢?他给的答案就是“speed” ,我们追求速度就像赛车手追求速度一样!
  
   现在很多系统的开发都不会把速度放在第一位,其他如:稳定性,安全性,可重用性等往往最优先考虑的。现在设计模式,开发架构等主要都不是为了解决性能问题的。以上这些都是分析师,架构师考虑的,像我们一些小小的程序员就只能在代码的一些小地方,一个类,一个方法,一行代码上面来优化程序。我觉得多注意一些细节上的东西还是很好的。
   
    好了废话说了一大堆,现在来说说今天的主题,现在开发的很多网络系统性能开销主要是在数据的读取,传输上,更快的读取速度,更少的网络宽带占用是我们追求的目标。我就从这方面来谈谈如何提高.net的性能。
   
    1. 在数据层分页数据。可以通过excutereader或者存储过程实现,方法很多,我就不多说了.(可以看看我写的   )   

    2. 尽量使用excutereader来读取数据,excutereader是效率最高的,在microsoft的petshop 4.0全部数据访问都是用excutereader来实现的,除非你对非连接有特殊要求(如 smartclient智能客户端等)。

    3. 在非连接场合,用datatable比用dataset性能好,除非你要保存多个关系表。

    4. 使用datatable的importrow方法。
       有些场合需要把大量数据从一个datatable复制到另一个datatable,使用datatable的importrow方法可以大大提高性能,数据量少时没多大分别,当数据量到一万行以上时就可以明显的提高,可以达到几倍。

    5. 把数据序列化为二进制文件方便传输。
     我们在处理dataset,datatable对象时可以序列化为xml文件,如果要在网络传输,xml文件会产生内存,网络带宽等资源问题。这时我们就可以把它序列化为二进制文件,这样生成的文件会减少很多,代码如下:
       filestream fs = new filestream(@"xmldata.bin",filemode.create);
       binaryformatter bf = new binaryformatter();
       bf.serialize(fs,xmldata);
       fs.colse();
     这样生成的二进制文件称为xmlbinary,用winhex直接打开还可以看到一些xml标记在里面,如果数据量很大,这时加一行代码:
     xmldata.remortingformat = serializationformat.binary;
     这时生成的文件称为truebinary文件,当处理大量(超过10000行)时生成的文件尺寸是xmlbinary的几分之一。序列化的时候会自动保存模式,这样解序过程很简单。我还不知道解序比直接读取xml性能会下降多少。
   
    6. 合理利用连接池。
    连接池对性能的提高有很大的作用,默认是打开的。默认的min pool size是0,一般设为一个比较小的值,如5。max pool size默认是100,大多数web站点也够用,大型的适当增大。

    7. 使用sqlclr开发
    如果你是专注开sql server系列那你应该去研究一下sqlclr,它的功能非常强大,在很多场合都可以提高性能(特别是大型企业级应用)。

    8. 通过静态类来访问app.config/web.config
    我们有很多配置信息都是放在app.config/web.config,访问都会很频繁,这时建立一个静态类,所有的属性都通过静态类来访问,可以在一定程度提高性能,静态类只实例化一次,而app.config/web.config会产生很多io操作。
    public static class mywebconfig
{
 
  static mywebconfig()
  {
    connstring =
configurationmanager.connectionstrings["connection"].
connectionstring;
  
  }
 
  public static string dbconnectionstring
  {
    get
    {
      return connstring;
    }
  }
}
 

好了 今天就写到这里, 有什么错误和不足的地方希望指出,欢迎提出更好的意见,共同进步。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表