乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      Asp.Net性能優(yōu)化

       suweixin 2011-01-15

      (一).選擇會(huì)話狀態(tài)存儲(chǔ)方式

          在Webconfig文件配置:

          <sessionState mode="???" stateConnectionString="tcpip=127.0.0.1:42424"
               sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"
            cookieless="false" timeout="20"/>
           
          Asp.net有三種方式存儲(chǔ)會(huì)話狀態(tài)信息:

          1. 存儲(chǔ)在進(jìn)程中: 屬性mode = InProc

             特點(diǎn):  具有最佳的性能,速度最快,但不能跨多臺(tái)服務(wù)器存儲(chǔ)共享.

          2. 存儲(chǔ)在狀態(tài)服務(wù)器中: 屬性mode = "StateServer"

             特點(diǎn): 當(dāng)需要跨服務(wù)器維護(hù)用戶會(huì)話信息時(shí),使用此方法。但是信息存儲(chǔ)在狀態(tài)服務(wù)器上,一旦狀態(tài)服務(wù)器出現(xiàn)故障,信息將丟失
         
          3. 存儲(chǔ)在Sql Server中: 屬性mode="SqlServer"

             特點(diǎn):   工作負(fù)載會(huì)變大,但信息不會(huì)丟失.
         
          補(bǔ)充一點(diǎn):

             I. 由于某些頁面不需要會(huì)話狀態(tài),則可以將會(huì)話狀態(tài)禁用:
                   代碼如下: <%@ Page EnableSessionState="false" %>
             II.如果頁面需要訪問會(huì)話變量但不允許修改它們,可以設(shè)置頁面會(huì)話狀態(tài)為只讀:
                   代碼如下: <%@ Page EnableSessionState="false" %>
         
          使用時(shí)可以根據(jù)具體情況選擇某種方式

        (二).使用Page.IsPostBack

          Page.IsPostBack表示是否是從客戶端返回的. 初次運(yùn)行時(shí),不是從客戶端返回,它的值為false,當(dāng)觸發(fā)頁面上的事件或刷新頁面時(shí),Page.IsPostBack由于是回發(fā)的,值變?yōu)閠rue;
         
          一般在:  Page_Load方法中用:
          private void Page_Load(Object sender,EventArgs e)
          {
              if(!Page.IsPostBack)
              {
                   ....;  //初始化頁面的代碼。這些代碼第一次頁面初始化時(shí)執(zhí)行,當(dāng)?shù)诙位匕l(fā)時(shí),
                          //不會(huì)再執(zhí)行。提高效率。 
              }
          }
         
          往往很多時(shí)候不得不用IsPostBack, 因?yàn)橛行┛丶跏蓟?,要保持它的狀態(tài).

          例如: DropDownList,如果每次都初始化,則用戶無論選擇其選項(xiàng),都會(huì)被初始化為默認(rèn)值.

        (三).避免使用服務(wù)器控件

          1.一般的靜態(tài)顯示信息,盡量不要用服務(wù)端控件顯示. 因?yàn)榉?wù)端控件需要回發(fā)服務(wù)端執(zhí)行,會(huì)降低程序執(zhí)行效率,一般用<DIV>顯示即可. 如果用了服務(wù)端控件,將: runat="server"去掉,也會(huì)提高效率.

          2.禁用服務(wù)端控件的狀態(tài)視圖,有些控件不需要維護(hù)其狀態(tài),可以設(shè)置其屬性:

      EnableViewState=false;

            如果整個(gè)頁面控件都不需要維持狀態(tài)視圖,則可以設(shè)置整個(gè)頁面的狀態(tài)視力為false:

               代碼如下: <%@ Page EnableViewState="false"%>

          3.在Web.Config文件中配置:

                ASP.NET Sessionss可以在Web.config或Machine.config中的Sessionsstate元素中配置。 下面是在 Web.config中的設(shè)置的例子:

                  <Sessionsstate timeout="10" cookieless="false" mode="Inproc" />

        (四).避免使用DataGrid

          大家都知道DataGrid功能強(qiáng)大。 但是功能強(qiáng)大的同時(shí),增加了性能上的開銷。 一般用其它控件: DataList或Repeater控件能實(shí)現(xiàn)的,盡量不用DataGrid.

        (五).字符串操作

          1.避免裝箱操作.  裝箱操作運(yùn)行效率比較低.
            例如運(yùn)行兩個(gè)代碼段:  
             
               string test="";
               for(for int i=0;i<10000;i  )
               {
                   test = test   i;            
               }
               和
                        string test="";
               for(for int i=0;i<10000;i  )
               {
                   test = test   i.ToString();            
               }
             下面的代碼段顯然效率要高.因?yàn)閕是整型的,系統(tǒng)要先把i進(jìn)行裝箱轉(zhuǎn)換為string型的,再進(jìn)行連接. 需要時(shí)間,讀者可以Copy到自己機(jī)器上測試一下.

           2.使用StringBulider類

             在進(jìn)行字符串連接時(shí):  string str = str1   str2   ....;

             一般超過三項(xiàng)連接,最好用StringBuilder來代替String類.  StringBuilder可以避免重新創(chuàng)建String 對(duì)象造成的性能損失.

             一般用于組裝Sql語句時(shí)用到: StringBulider.讀者可以到自己機(jī)器上測試一下.

        (六).ADO.Net使用方面優(yōu)化

           1.數(shù)據(jù)庫連接打開和關(guān)閉。  在需要連接時(shí)打開,當(dāng)訪問完數(shù)據(jù)庫要立刻關(guān)閉連接.

             舉例說明,還是看兩個(gè)代碼段:

              I.
                 DataSet ds = new DataSet();
                 SqlConnection MyConnection = new SqlConnection("server=localhost; uid=sa; pwd=; database=NorthWind");
                 SqlCommand myCommand = new SqlCommand(strSql,MyConnection);  
                 SqlDataAdapter myAdapter=new SqlDataAdapter(queryStr,connectionStr);
              MyConnection.Open();      //打開連接
               for(int i=0;i<1000;i  )   //for循環(huán)模擬取得數(shù)據(jù)前的商業(yè)邏輯操作
               {
                  Thread.Sleep(1000);
             }
             myAdapter.Fill(ds);
              for(int i=0;i<1000;i  )   //for循環(huán)模擬取得數(shù)據(jù)后的商業(yè)邏輯操作
              {
                 Thread.Sleep(1000);
              }
              MyConnection.Close();     //關(guān)閉連接
              II.
                 DataSet ds = new DataSet();
                 SqlConnection MyConnection = new SqlConnection("server=localhost; uid=sa; pwd=; database=NorthWind");
                 SqlCommand myCommand = new SqlCommand(strSql,MyConnection);  
                 SqlDataAdapter myAdapter=new SqlDataAdapter(queryStr,connectionStr);       
               for(int i=0;i<1000;i  )   //for循環(huán)模擬取得數(shù)據(jù)前的商業(yè)邏輯操作
               {
                  Thread.Sleep(1000);
             }
             MyConnection.Open();      //打開連接
                 myAdapter.Fill(ds);
                MyConnection.Close();     //關(guān)閉連接
              for(int i=0;i<1000;i  )   ////for循環(huán)模擬取得數(shù)據(jù)后的商業(yè)邏輯操作
              {
                 Thread.Sleep(1000);
              }

               顯示II代碼比I代碼好的多,I中早早占著連接不放,如果用戶很多的話,容易出現(xiàn)連接池滿情況。嚴(yán)重時(shí)出現(xiàn)死機(jī)現(xiàn)象.

             2.數(shù)據(jù)庫查詢

                I.  直接生成SQL語句。 Sql Server每次都要對(duì)其進(jìn)行編譯,在性能方面不會(huì)有很大的提高。 另外也不夠安全。容易被攻擊.

                II. 使用帶參數(shù)的SQL命令。這種方式Sql Server只對(duì)其編譯一次,對(duì)于不同的參數(shù)可以重復(fù)使用編譯后的命令。提高了性能.

                III.使用Sql Server存儲(chǔ)過程. 編譯一次. 具有獨(dú)立性,便于修改和維護(hù).  一次能完成用語句發(fā)送多次的功能.減少了網(wǎng)絡(luò)的流量。  并不一定存儲(chǔ)過程一定比語句效率要高,如果商業(yè)邏輯很復(fù)雜的話,有時(shí)候用語句比存儲(chǔ)過程效率要高.

        (六).緩存優(yōu)化

           緩存分為兩種: 頁面緩存和API緩存.

          1.使用頁面緩存和片段緩存 

              <%@ OutputCache Duration="5" VaryByParam="None"%> 
              <%@ OutputCache Duration=60 VaryByParam=”TextBox1,TextBox2” %>

            說明: Duration是設(shè)置Cache的過期時(shí)間;

                VarByParam是設(shè)置是否根據(jù)參數(shù)而變化,None時(shí)所有參數(shù)使用同一Cache,設(shè)置TextBox1時(shí)則根據(jù)TextBox1的不同值分別緩存;當(dāng)有多個(gè)參數(shù)時(shí)則要組合緩存;

          2.API緩存。用于在應(yīng)用程序中使用

             I. 一個(gè)Cache使用的例子:

                 http://blog.csdn.net/chengking/archive/2005/10/03/494545.aspx

             II.使用時(shí)注意Page.Cache和HttpContext.Current.Cache區(qū)別:

                它們指的同一個(gè)對(duì)象,在Page里,用Page.Cache,如果在global.asax或自己的類里用:HttpContext.Current.Cache,在有些事件中,由于其沒有HttpContext,就用HttpRuntime.Cache.

        不對(duì)的地方請讀者批評(píng)指正!

              
      Tags: dotnet技術(shù) , c#開發(fā)技術(shù)


      本文來自CSDN博客,轉(zhuǎn)載請標(biāo)明出處:http://blog.csdn.net/longge7685/archive/2010/01/03/5123779.aspx

        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請遵守用戶 評(píng)論公約

        類似文章 更多