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

性能

   昨天发了一篇如何最大限度提高.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;
    }
  }
}
 

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

时间: 2024-09-07 07:34:10

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

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

性能 优化 .NET的性能 1)避免使用ArrayList.     因为任何对象添加到ArrayList都要封箱为System.Object类型,从ArrayList取出数据时,要拆箱回实际的类型.建议使用自定义的集合类型代替ArrayList..net 2.0提供了一个新的类型,叫泛型,这是一个强类型,使用泛型集合就可以避免了封箱和拆箱的发生,提高了性能. 2)使用HashTale代替其他字典集合类型(如StringDictionary,NameValueCollection,HybridC

关于大小型项目如何最大限度提高WebAPi性能

前言 WebAPi作为接口请求的一种服务,当我们请求该服务时我们目标是需要快速获取该服务的数据响应,这种情况在大型项目中尤为常见,此时迫切需要提高WebAPi的响应机制,当然也少不了前端需要作出的努力,这里我们只讲述在大小型项目中如何利用后台逻辑尽可能最大限度提高WebAPi性能,我们从以下几个方面来进行阐述. 性能提升一:JSON序列化器(Jil) 在.NET里面默认的序列化器是JavaScriptSrializer,都懂的,性能实在是差,后来出现了Json.NET,以至于在目前创建项目时默认

设置DB2和AIX与条带技术匹配以提高I/O性能

条带化技术是一种广泛使用的 I/O 负载均衡技术,可以在不增加额外硬件投入的情况下极大的提高 I/O 性能.但是在使用了这种技术的环境中,只有对数据库和操作系统的 I/O 处理有良好的规划和设置,使其与条带化技术相匹配,才能使 I/O 的性能达到最好.本文针对这个主题,以 DB2 数据库和 AIX 操作系统为例,介绍了如何规划和设置好相关的内容. 下面我们分如下几个方面来介绍: 条带化技术介绍 在 DB2 中合理规划和设置条带有关参数 在 AIX 中合理规划和设置条带有关参数 总结 条带化技术介

使用智能优化器提高Oracle的性能极限

oracle|性能|优化  使用智能优化器提高Oracle的性能极限       消耗在准备新的SQL语句的时间是Oracle SQL语句执行时间的最重要的组成部分.但是通过理解Oracle内部产生执行计划的机制,你能够控制Oracle花费在评估连接顺序的时间数量,并且能在大体上提高查询性能.准备执行SQL语句       当SQL语句进入Oracle的库缓存后,在该语句准备执行之前,将执行下列步骤: 1)        语法检查:检查SQL语句拼写是否正确和词序. 2)        语义分析

提高DB2查询性能的常用方法

简介 随着DB2应用的逐渐增多,越来越多的数据库开发人员在项目开发过程中都会遇到查询过于复杂,导致性能难以接受的问题.本文将主要从一个数据库开发者的角度介绍几种常用的方法来提高 DB2 查询的性能,而并不讨论如何通过配置 DB2 的各项参数以及调整服务器环境等方式来提高整个数据库性能的方法.系统配置等工作属于 DBA 的工作范畴,在一般的项目开发中,这对于开发人员都是透明的.本文先对 DB2提供的几种用于提高查询性能的相关工具和命令进行介绍,然后根据笔者的工作经验介绍一些常用的技巧和方法来提高查

用智能优化限制提高Oracle数据库性能

Oracle SQL运行时间的最主要的组成部分是花在为执行准备新的SQL语句上的时间.不过,如果了解了可执行计划产生的内在机制,你就可以控制Oracle花费在评估表的连接顺序的时间,并在总体上提高查询的性能. 准备为执行提供的SQL语句 在一个SQL语句进入Oracle库的cache之后.而真正被执行之前,将会依次发生如下事件: 语法检查--检查该SQL语句的拼写和词序是否正确. 语义解析--Oracle根据数据词典(data dictionary)来验证所有的表格(table)和列(colum

提高大容量内存性能,这是你内存大最应该做的事。

现在很多人的内存都有8G.16G甚至32G之类的超大内存,这是我们最应该考虑的是提高大容量内存性能 ,也就是让你的内存能发挥最大的功效.而不是有着大内存且没感觉到比以前低内存快多少.发生这种事就是你电脑设置得不够好. 1 根据我所知道的,可以改3个地方,下面就跟着我一一来修改吧. 3个地方都是在注册表哦,所以我们要先进入注册表编辑器,运行输入:regedit就进入了. 2 第一个要改的是LargeSystemCache的值 LargeSystemCache默认值为4,也就是4M,这个值是系统缓存

使用虚拟化,能够提高服务器的性能吗?

问题描述 我现在有两台2U双路服务器,性能中等,CPU也支持虚拟化.我计划在这两台服务器上,安装多个vmware的虚拟机,并在虚拟机中安装操作系统和我的多个业务系统.业务系统中,有大量的网络通信,也有一部分数据需要写入到数据库中.我想问一下,相比在物理机中安装.运行我的业务系统,在虚拟机中安装运行业务系统,能够提高服务器的性能吗? 解决方案 解决方案二:不能但是能提高安全性和部署配置灵活性

10款Web工具最大限度提高生产力

企业生产力的面貌在过去五年中发生了巨大的变化.大多数我们曾经在工作中以来的客户端和客户端/服务器端应用已经一去不复返了.现在,业务速度是由网络来定义的.因此这种从本地安装客户端应用向基于Web应用的转移,你需要重新装备那些帮助用户完成工作的工具.因此,你需要考虑那些基于Web的生产力工具. 不管你信或者不信,这些工具中很多远比你一直在使用的工具更具成本效益.此外,它们还有更高的可靠性,你创建一个环境,在这个环境中员工可以有效率地工作.但是你应该考虑哪些工具?以下是可能适合你的商业模式的10款工具