国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

asp.net模板引擎Razor中cacheName的問題分析

2024-07-10 13:29:08
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了asp.net模板引擎Razor中cacheName的問題,實例分析了cacheName在提高編譯效率方面的使用技巧,需要的朋友可以參考下

本文實例講述了asp.net模板引擎Razor中cacheName的問題。分享給大家供大家參考。具體如下:

一、為什么使用cacheName

使用cacheName主要是考慮到Razor.Parse()每解析一次都會動態創建一個程序集,如果解析量很大,就會產生很多程序集,大量的程序集調用會造成程序非常慢。

舉個例子:

如果編譯1000次,編譯速度就會很慢。

 

 
  1. static void Main(string[] args) 
  2. string cshtml = File.ReadAllText(@"E:/百度云同步盤/Study/Net_ASP.NET/Web基本原理/RazorCacheNameTest/HTMLPage1.cshtml"); 
  3. for (int i = 0; i < 1000; i++) 
  4. string html = Razor.Parse(cshtml);  
  5. Assembly[] asms = AppDomain.CurrentDomain.GetAssemblies(); 
  6. foreach (Assembly asm in asms) 
  7. Console.WriteLine(asm.FullName+"/r/n"); 
  8. Console.ReadKey(); 

二、如何解決這個問題

使用Razor.Parse()時,帶上cacheName參數。

指定一個cacheName叫cc,下次Parse()解析時就不會重新編譯了(除非cshtml內容修改,那么cacheName名也要重新命名,讓Parse()解析新文件)

 

 
  1. for (int i = 0; i < 1000; i++) 
  2. //如果調用1000次,使用下面方式就會創建很多程序集,性能很低 
  3. string html = Razor.Parse(cshtml);  
  4. //解析的cshtml文件我給的一個“緩存名”是cc,這次一旦編譯成功 
  5. //下次再讓你Parse() cc就不用重復編譯了,速度會非常快, 
  6. //除非cshtml內容修改 
  7. Razor.Parse(cshtml, null"cc"); 

三、怎么確定cacheName表示的文件已修改呢?

有兩種方式,一種就是文件全路徑+文件修改時間,還可以根據cshtml文件的MD5值。

 

 
  1. for (int i = 0; i < 10; i++) 
  2. string cshtml = File.ReadAllText(fullPath); 
  3. string cacheName = fullPath + File.GetLastWriteTime(fullPath); 
  4. //文件全路徑+文件上一次被修改時間 
  5. string html = Razor.Parse(cshtml,null,cacheName); 
  6. Console.WriteLine(html); 
  7. Console.ReadKey(); 

每當cshtml文件被修改,cacheName的值就會改變,Parse()根據cacheName值判斷是否重新編譯。假如測試過程中對cshtml文件做了三次修改,最終會生成三個程序集,如果cshtml文件未修改,最后只有一個程序集。

注意:關于cacheName的問題。

經過試驗發現,即使cacheName寫成一個固定的值,當cshtml發生改變的時候Parse的結果也是修改后的內容,這是為什么呢?

經過反編譯我們發現Parse方法最終調用的是TemplateService的GetTemplate方法,代碼如下:

 

 
  1. private ITemplate GetTemplate<T>(string razorTemplate, object model, string cacheName) 
  2. Func<string, CachedTemplateItem, CachedTemplateItem> updateValueFactory = null
  3. CachedTemplateItem item; 
  4. if (razorTemplate == null
  5. throw new ArgumentNullException("razorTemplate"); 
  6. int hashCode = razorTemplate.GetHashCode(); 
  7. if (!this._cache.TryGetValue(cacheName, out item) || (item.CachedHashCode != hashCode)) 
  8. Type templateType = this.CreateTemplateType(razorTemplate, (model == null) ? typeof(T) : model.GetType()); 
  9. item = new CachedTemplateItem(hashCode, templateType); 
  10. if (updateValueFactory == null
  11. updateValueFactory = (n, i) => item; 
  12. this._cache.AddOrUpdate(cacheName, item, updateValueFactory); 
  13. return this.CreateTemplate(null, item.TemplateType, model); 

代碼大意是:從緩存cache中查找是否有名字等于cacheName的緩存項“TryGetValue(cacheName, out item)”,如果不存在,則編譯創建;如果存在,則再檢查緩存中的cshtml內容的hashCode(字符串的特征碼,相同的字符串的HashCode一樣,不同字符串的HashCode有一樣的概率)和這次傳進來的razorTemplate的HashCode是否一樣,如果不一樣也重新編譯創建,而不使用緩存的。

因此這就能解釋為什么用一個固定的cacheName,只要修改cshtml的內容,還是會Parse出新內容了。

有同學會問:既然修改cshtml后,就會重新Parse新內容,那要cacheName還有什么意義呢?這是因為不同的字符串的HashCode相同的概率很低,但并不是沒有“A、B兩個字符串不一樣,但是hashcode相同”這種可能,因此如果只依賴HashCode的話,那么有這樣的概率“cshtml的文件修改了,但是恰好修改后的HashCode和修改以前是一樣的,那么Parse還是執行舊的邏輯”。所以加上cacheName才是“雙保險”。

希望本文所述對大家的asp.net程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 延津县| 景谷| 广汉市| 会泽县| 阜城县| 青龙| 渝中区| 饶河县| 临澧县| 周至县| 金昌市| 两当县| 乌苏市| 甘谷县| 永寿县| 迁安市| 三门县| 宁城县| 利辛县| 亚东县| 长泰县| 襄汾县| 平和县| 内江市| 民丰县| 阜宁县| 鸡东县| 蛟河市| 舟山市| 如东县| 城固县| 班戈县| 城步| 瓮安县| 安福县| 晋城| 清镇市| 营口市| 遂溪县| 泾阳县| 安西县|