| 
   .net2.0的winform客户端最常用的与服务端通信方式是通过webservice,最近在用dottrace对客户端做性能测试的时候发现,客户端程序启动以后,第一次调用某一个webservice的方法是,总是特别慢,大概需要0.8-1秒钟的时间,而接下来掉其他方法就很快了,都只需要几十毫秒。google了一把,找到解决办法:  
  在应用程序的config文件中加入以下配置节:  
 
 <system.net>
    <defaultProxy enabled="false" useDefaultCredentials="false">
      <proxy/>
      <bypasslist/>
      <module/>
    </defaultProxy>
  </system.net> 
  
或者在程序入口加入以下代码:  
 
 HttpWebRequest.DefaultWebProxy = null;  
  
  msdn上的解释:  
属性 
    
  
 
  
   
    
    | 元素 |  
    说明 |  
     
    
    |   enabled   |  
      指定是否使用 Web 代理。默认值为 true。   |  
     
    
    |   useDefaultCredentials   |  
      指定是否使用此主机的默认凭据访问 Web 代理。默认值为 false。   |  
     
   
   
  
子元素 
    
  
 
父元素 
    
  
 
  
   据我的理解,由于web代理默认是开启的,也就是HttpWebRequest.DefaultWebProxy的值不为null,而这个DefaultWebProxy是一个全局变量。故第一次调用webservice方法的时候只有等这个默认代理超时以后才能绕过,所以第一次比较慢。  
   更多介绍请参考这里,还有这里  
  |