C# 第一次网络请求速度慢的原因

修改后代码如下:

 public string RequestServer(string requestUriString)
        {
            try
            {
                GC.Collect();
                var request = WebRequest.Create(requestUriString) as HttpWebRequest;
                if (request == null) throw new ArgumentNullException();

                request.Method = "Get";
                request.KeepAlive = false;
                // request.Timeout = 3000;
                request.Proxy = null;//去掉这条代码,坑能导致第一次访问很慢
                var response = request.GetResponse() as HttpWebResponse;


                var info = GetResponseString(response);

                Console.WriteLine(@"网络请求回应: {0}", info);


                request.Abort();


                return info;

            }
            catch (ArgumentNullException err)
            {
                Console.WriteLine(@"引用类型Null异常: {0} ;异常函数:{1}", err.Message, MethodBase.GetCurrentMethod());
            }
            catch (WebException err)
            {
                Console.WriteLine(@"网络异常: {0}", err.Message);
            }
            catch (Exception err)
            {

                Console.WriteLine(@"常规异常: {0}", err.Message);
            }

            return null;

        }
    总结:
     request.Proxy = null是关键,默认使用代理模式,程序获取代理模式配置需要一定的时间。电脑性能好的话时间短,电脑性能差要的时间比较长。
     参考:[参考这个作者](http://www.cnblogs.com/TianFang/archive/2011/09/18/2180741.html)

posted on 2017-09-23 09:55  五月槐花  阅读(726)  评论(0编辑  收藏  举报

导航