zoukankan      html  css  js  c++  java
  • Go语言和ASP.NET的一般处理程序在处理WEB请求时的速度比较

    Go语言和ASP.NET的一般处理程序在处理WEB请求时的速度比较

    1、首先写一个Go语言的简单WEB程序,就返回一个HelloWord!

    package main
    
    import (
        f "fmt"
        "log"
        "net/http"
        //    "strings"
    )
    
    func sayhelloName(w http.ResponseWriter, r *http.Request) {
        //    r.ParseForm()
        //    f.Println(r.Form)
        //    f.Println("path", r.URL.Path)
        //    f.Println("scheme", r.URL.Scheme)
        //    f.Println(r.Form["url_long"])
        //    for k, v := range r.Form {
        //        f.Println("key:", k, "val:", strings.Join(v, "、"))
        //    }
    
        f.Fprintln(w, "hello world!")
    }
    func main() {
        http.HandleFunc("/", sayhelloName)
        err := http.ListenAndServe(":8080", nil)
        if err != nil {
            log.Fatal("ListenAndServe:", err)
        }
    }

    2、建一个Asp.net的Handler1.ashx的一般处理程序,并运行于IIS中。

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    
    namespace TESTWeb
    {
        /// <summary>
        /// Handler1 的摘要说明
        /// </summary>
        public class Handler1 : IHttpHandler
        {
    
            public void ProcessRequest(HttpContext context)
            {
                context.Response.Write("hello world!");
            }
    
            public bool IsReusable
            {
                get
                {
                    return false;
                }
            }
        }
    }

    3、用C#写一个控制台程序,用来模拟发起10000次请求时,速度比较:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Net;
    using System.Text;
    
    namespace TESTSpeed
    {
        class Program
        {
            static void Main(string[] args)
            {
          
                WebClient wc = new WebClient();
                DateTime dt1 = DateTime.Now;
                for (int i = 0; i < 10000; i++)
                {
                    var result = wc.DownloadString("http://localhost:48563/handler1.ashx?t=" + DateTime.Now.Ticks);
                }
                DateTime dt2 = DateTime.Now;
                Console.WriteLine("Asp.net一般处理程序用时:" + (dt2 - dt1).TotalMilliseconds);
    
                WebClient wc2 = new WebClient();
                DateTime dt3 = DateTime.Now;
                for (int i = 0; i < 10000; i++)
                {
                    var result = wc2.DownloadString("http://127.0.0.1:8080/?t=" + DateTime.Now.Ticks);
                }
                DateTime dt4 = DateTime.Now;
                Console.WriteLine("Go语言用时:" + (dt4 - dt3).TotalMilliseconds);
            }
        }
    }

    4、测试结果:

    Go语言用时:811.0464ms

    Asp.net一般处理程序:14017.8017ms

    5、结论:Go不是一般的快!!!!相差了17倍!!!

  • 相关阅读:
    windows 乱码之 gbk 与 cp936
    jdcli 在命令行反编译jar包
    建议博客园向独立博客提供发布到首页的服务
    IsByRef在什么情况下为true?
    Hibernate里自定义UserType时取不到值的问题
    解决安装Visual Studio 2010 SP1时被NDP40KB2468871.exe补丁卡死以及mscorsvw.exe进程CPU占用率高的问题
    FROM WAS7/JDK5 TO WAS6/JDK4
    C++山寨C#中的DataTable
    程序员的自我修养读书笔记
    Web开发之路
  • 原文地址:https://www.cnblogs.com/songxingzhu/p/5021969.html
Copyright © 2011-2022 走看看