你們先看看我上一次的文章html
大體以下瀏覽器
//定義一個委託 private delegate void actionByMain(HttpContext context); //定義一Key,Value的鍵值對,你們注意這裏把委託放進去了 private static Dictionary<string, actionByMain> mainList = new Dictionary<string, actionByMain>(); public void ProcessRequest(HttpContext context) { string action = string.Empty; if (string.IsNullOrEmpty(context.Request["action"])) { return; } action = context.Request["action"]; //先檢查一下有沒有這個action if (mainList.ContainsKey(action)) { mainList[action](context); return; } } //添加action對應方法的列表 構造器 static addMainList() { mainList.Add("post1", delegate(HttpContext context) { context.Response.Write("成功"); }); mainList.Add("post2", delegate(HttpContext context) { context.Response.Write("成功"); }); mainList.Add("post3", delegate(HttpContext context) { return; }); }
就是這樣的寫法,容易出現問題緩存
在高併發的時候常常出現頁面沒法訪問的問題併發
其實我也不敢肯定是否是這裏的問題可是有如下幾點能夠肯定高併發
可能會有人說,若是不使用這種而是直接調用靜態方法呢,是同樣的效果。這點我測試過。post
換成普通類型測試
換成以下寫法就不會出現這樣的問題spa
//取出action的值 string action = context.Request["action"]; if (action == "post1") { //調用第一個Post方法 } else if (action == "post2") { //調用第一個Post方法 } else if (action == "post3") { //調用第一個Post方法 } else { //調用在沒有找到action對應方法時執行 }
方法以下code
private void post1() { } private void post2() { } private void post3() { }
訪問量比較小時,本頁面日訪問量低於2萬Pv的就不要測試了,應該不會有效果htm
這個我通過測試肯定是這樣的
由於通過咱們的測試,只要清理一下瀏覽器的緩存或者是重啓電腦路由以後就基本上又能夠正常訪問了。
這種現像很難解釋啊,
因此沒有辦法後來我又修改爲了。普通的寫法。
你們討論一下看看具體是那裏的問題
我確實是解釋不了這種現像了。