<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

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

        來源:懂視網 責編:小采 時間:2020-11-27 22:38:31
        文檔

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

        asp.net模板引擎Razor中cacheName的問題分析:本文實例講述了asp.net模板引擎Razor中cacheName的問題。分享給大家供大家參考。具體如下: 一、為什么使用cacheName 使用cacheName主要是考慮到Razor.Parse()每解析一次都會動態(tài)創(chuàng)建一個程序集,如果解析量很大,就會產生很多程序集,大量的程序集調用會造成
        推薦度:
        導讀asp.net模板引擎Razor中cacheName的問題分析:本文實例講述了asp.net模板引擎Razor中cacheName的問題。分享給大家供大家參考。具體如下: 一、為什么使用cacheName 使用cacheName主要是考慮到Razor.Parse()每解析一次都會動態(tài)創(chuàng)建一個程序集,如果解析量很大,就會產生很多程序集,大量的程序集調用會造成

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

        一、為什么使用cacheName

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

        舉個例子:

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

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

        二、如何解決這個問題

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

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

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

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

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

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

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

        注意:關于cacheName的問題。

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

        經過反編譯我們發(fā)現(xiàn)Parse方法最終調用的是TemplateService的GetTemplate方法,代碼如下:

        private ITemplate GetTemplate<T>(string razorTemplate, object model, string cacheName)
        {
         Func<string, CachedTemplateItem, CachedTemplateItem> updateValueFactory = null;
         CachedTemplateItem item;
         if (razorTemplate == null)
         {
         throw new ArgumentNullException("razorTemplate");
         }
         int hashCode = razorTemplate.GetHashCode();
         if (!this._cache.TryGetValue(cacheName, out item) || (item.CachedHashCode != hashCode))
         {
         Type templateType = this.CreateTemplateType(razorTemplate, (model == null) ? typeof(T) : model.GetType());
         item = new CachedTemplateItem(hashCode, templateType);
         if (updateValueFactory == null)
         {
         updateValueFactory = (n, i) => item;
         }
         this._cache.AddOrUpdate(cacheName, item, updateValueFactory);
         }
         return this.CreateTemplate(null, item.TemplateType, model);
        }
        
        

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

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

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

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

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

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

        asp.net模板引擎Razor中cacheName的問題分析:本文實例講述了asp.net模板引擎Razor中cacheName的問題。分享給大家供大家參考。具體如下: 一、為什么使用cacheName 使用cacheName主要是考慮到Razor.Parse()每解析一次都會動態(tài)創(chuàng)建一個程序集,如果解析量很大,就會產生很多程序集,大量的程序集調用會造成
        推薦度:
        標簽: 問題 模板 的問題
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲av丰满熟妇在线播放| 亚洲成?v人片天堂网无码| 亚洲欧洲在线观看| 一区二区三区无码视频免费福利| 亚洲精品国自产拍在线观看| 久久亚洲欧美国产精品| 日韩精品免费一区二区三区| 亚洲aⅴ无码专区在线观看| 在线观看人成视频免费| 国产成人亚洲精品无码AV大片| 蜜臀91精品国产免费观看| 亚洲国产精品日韩av不卡在线| 无码一区二区三区免费视频| 亚洲91精品麻豆国产系列在线| 最近免费中文字幕视频高清在线看 | 亚洲第一福利网站在线观看| 久久综合亚洲色hezyo| 无码中文在线二区免费| 亚洲中文无码mv| 亚洲国产精品成人AV无码久久综合影院 | 中文字幕第13亚洲另类| 一级美国片免费看| 亚洲精品国产成人片| 蜜桃视频在线观看免费视频网站WWW| 亚洲av永久无码精品漫画 | 毛片基地免费视频a| 免费精品久久久久久中文字幕| 亚洲人成网77777亚洲色| 亚洲一区在线免费观看| 亚洲AV无码一区二区三区牲色| 中文字幕亚洲一区二区三区| 中文字幕免费观看| 国产精品亚洲AV三区| 精品亚洲视频在线观看| 久久国产色AV免费观看| 亚洲av无码成人精品国产| 久久夜色精品国产亚洲AV动态图 | 3d成人免费动漫在线观看| 亚洲一区二区观看播放| 国产亚洲美女精品久久久2020| 中国人xxxxx69免费视频|