asp.net小談網(wǎng)站性能優(yōu)化
1、書(shū)寫(xiě)代碼的習(xí)慣;
再?gòu)?fù)雜的邏輯,也是從最簡(jiǎn)單的開(kāi)始。在書(shū)寫(xiě)代碼的過(guò)程中,很多不好的規(guī)范都會(huì)影響網(wǎng)站的性能;
以下是整理出來(lái)的些許代碼習(xí)慣:
1)字符串的比較 用 string.Empty 代替 " "
2)在遍歷過(guò)程中,先定義好計(jì)數(shù)變量, 再遍歷, 這樣會(huì)減少每次遍歷就分配一次內(nèi)存空間:
int i;
for( i=0; i<100;i++)
{
// codeing
}
3)同樣的,用 StringBuilder.Append() 代替 [csharp] string +="ABC" [/csharp];
4)在遍歷循環(huán)中中處理邏輯而不要調(diào)用其他方法形式,那樣在調(diào)用時(shí)會(huì)有性能損耗
5)累加/減時(shí),使用 A+=1,A-=1 ;而不用 A=A+1;這樣減緩申請(qǐng)內(nèi)存的次數(shù)
6)多用集合操作
a:如果如果集合中元素類(lèi)型固定,則可以使用它們各自對(duì)應(yīng)的集合類(lèi),如數(shù)組、泛型等,這樣可以避免裝箱、拆箱操作;
b:如果集合中元素個(gè)數(shù)固定并且類(lèi)型一致,則使用數(shù)組存儲(chǔ);
c:如果對(duì)集合的操作主要是查找方面的,可以使用HashTable,Dictionaty<TYey,TValue>
7) 使用Server.Transfer 來(lái)進(jìn)行頁(yè)面重定向
好處:性能比response.redirect要好很多,而且具有隱藏URL的好處,可以避免客戶(hù)端進(jìn)行頁(yè)面重定向;
壞處:要是用戶(hù)用刷新或是后退會(huì)導(dǎo)致發(fā)生意外的情況,所以請(qǐng)慎用
8)減少服務(wù)器控件的運(yùn)用
9)合理(適當(dāng)時(shí)候)使用緩存
10)減少Cookies大小
... ...
2、數(shù)據(jù)庫(kù)
1)數(shù)據(jù)庫(kù)最遲打開(kāi)、最早關(guān)閉;
2)優(yōu)化數(shù)據(jù)庫(kù)連接配置,對(duì)于大型網(wǎng)站由于數(shù)據(jù)庫(kù)中存在大量的數(shù)據(jù),所以可以加大其數(shù)據(jù)庫(kù)連接池
Max Pool Size=512;(默認(rèn)為100)
3)優(yōu)化SQL語(yǔ)句,并使用存儲(chǔ)過(guò)程
注意:盡量避免“select * from”之類(lèi)的sql語(yǔ)句;盡量不要再查詢(xún)語(yǔ)句中使用子查詢(xún);盡量使用索引;
4)使用DataReader
在 DataReader 中,我們經(jīng)常會(huì)用dr["字段名"]的查找形式,但是這種寫(xiě)法卻是最耗性能的;
一般,使用基于「序列號(hào)」的查找,比基于「命名」的查找更有效率。其中,可分為4類(lèi):
寫(xiě)法 (1) 使用 DataReader 索引 + 基于「序列號(hào)」的查找,如:dr[1].ToString(),
寫(xiě)法 (2) 使用 DataReader 索引 + 基于「命名」的查找,如:dr["LastName"].ToString(),這是性能最不好的寫(xiě)法
寫(xiě)法 (3) 使用 Get 開(kāi)頭的方法 + 基于「序列號(hào)」的查找,如:dr.GetString(1),寫(xiě)法
寫(xiě)法 (4) 使用 GetSql 開(kāi)頭的方法 + 基于「序列號(hào)」的查找,如:dr.GetSqlString(1),
寫(xiě)法 (5)使用 基于「序列號(hào)」+ GetOrdinal() 方法的查找。
GetOrdinal()函數(shù)方法是什么呢?
我們從數(shù)據(jù)庫(kù)中書(shū)寫(xiě)對(duì)應(yīng)的字段到我們查找的序列號(hào)上,但是有時(shí)候插入新的字段時(shí),會(huì)有所變化。而GetOrdinal()的作用就是讓我們自己來(lái)序列化相對(duì)應(yīng)的字段。
a、首先定義序列號(hào) int classid,classnameid;
b、然后通過(guò)GetOrdinal()方法賦予新的序列號(hào);
c、通過(guò)GetSqlSring( 序列號(hào) ) 方法就可找到對(duì)應(yīng)的字段。
示例代碼如下:
SqlConnection con = new SqlConnection(connString);
string strcmd = "select top 1 classid,classname where cms_class";
SqlCommand cmd = new SqlCommand(strcmd, con);
con.Open();
SqlDataReader dr = cmd.ExecuteReader();
int numberId, numberName;
numberId = Convert.ToInt32(dr.GetOrdinal("classid"));
numberName = Convert.ToInt32(dr.GetOrdinal("classname"));
con.Close();
if (dr.Read())
{
string result = dr.GetSqlString(numberId) + " | " + dr.GetSqlString(numberName);
}
dr.Close();
- ASP.NET性能優(yōu)化之局部緩存分析
- ASP.NET 性能優(yōu)化之反向代理緩存使用介紹
- ASP.NET性能優(yōu)化之讓瀏覽器緩存動(dòng)態(tài)網(wǎng)頁(yè)的方法
- ASP.NET性能優(yōu)化之構(gòu)建自定義文件緩存
- ASP.NET性能優(yōu)化小結(jié)(ASP.NET&C#)
- asp.net 程序性能優(yōu)化的七個(gè)方面 (c#(或vb.net)程序改進(jìn))
- ASP.NET比較常用的26個(gè)性能優(yōu)化技巧
- ASP.NET性能優(yōu)化之減少請(qǐng)求
- ASP.NET技巧:同時(shí)對(duì)多個(gè)文件進(jìn)行大量寫(xiě)操作對(duì)性能優(yōu)化
- asp.net性能優(yōu)化之使用Redis緩存(入門(mén))
相關(guān)文章
在.NET Core類(lèi)庫(kù)中使用EF Core遷移數(shù)據(jù)庫(kù)到SQL Server的方法
下面小編就為大家分享一篇在.NET Core類(lèi)庫(kù)中使用EF Core遷移數(shù)據(jù)庫(kù)到SQL Server的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
ASP.NET中DES加密與解密MD5加密幫助類(lèi)的實(shí)現(xiàn)代碼
這篇文章主要介紹了ASP.NET中DES加密與解密MD5加密幫助類(lèi)的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-07-07
ASP.net 動(dòng)態(tài)加載控件時(shí)一些問(wèn)題的總結(jié)
經(jīng)常見(jiàn)到有人說(shuō)在ASP.net中不要使用動(dòng)態(tài)控件,我想主要的原因在于使用動(dòng)態(tài)控件會(huì)帶來(lái)一些問(wèn)題,在做項(xiàng)目的過(guò)程中,我將由動(dòng)態(tài)加載控件引發(fā)的總是作了一個(gè)小小的總結(jié).2009-04-04
.Net使用RabbitMQ即時(shí)發(fā)消息Demo
RabbitMQ是一個(gè)在AMQP基礎(chǔ)上完整的,可復(fù)用的企業(yè)消息系統(tǒng),下面這篇文章主要給大家介紹了關(guān)于.Net使用RabbitMQ即時(shí)發(fā)消息的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-07-07
asp.net 1.1/ 2.0 中快速實(shí)現(xiàn)單點(diǎn)登陸
asp.net 1.1/ 2.0 中快速實(shí)現(xiàn)單點(diǎn)登陸...2007-04-04
asp.net實(shí)現(xiàn)生成縮略圖及給原始圖加水印的方法示例
這篇文章主要介紹了asp.net實(shí)現(xiàn)生成縮略圖及給原始圖加水印的方法,結(jié)合具體實(shí)例形式分析了asp.net圖片的縮略圖與水印操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-10-10
asp.net core webapi文件上傳功能的實(shí)現(xiàn)
這篇文章主要介紹了asp.net core webapi文件上傳功能的實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
在應(yīng)用程序級(jí)別之外使用注冊(cè)為allowDefinition=''MachineToApplication''的節(jié)是錯(cuò)誤的
在應(yīng)用程序級(jí)別之外使用注冊(cè)為 allowDefinition='MachineToApplication' 的節(jié)是錯(cuò)誤的2009-03-03
未將對(duì)象引用設(shè)置到對(duì)象的實(shí)例 (System.NullReferenceException)
System.NullReferenceException:未將對(duì)象引用設(shè)置到對(duì)象的實(shí)例,這是一個(gè)新鳥(niǎo),中鳥(niǎo),老鳥(niǎo)都避不開(kāi)的錯(cuò)誤2012-03-03
ASP.NET2.0服務(wù)器控件之類(lèi)型轉(zhuǎn)換器
ASP.NET2.0服務(wù)器控件之類(lèi)型轉(zhuǎn)換器...2006-09-09

