码迷,mamicode.com
首页 > 系统相关 > 详细

关于Razor中的cacheName的问题

时间:2015-06-07 17:16:16      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:

为什么使用cacheName

使用cacheName主要是考虑到Razor.Parse()每解析一次都会动态创建一个程序集,如果解析量很大,就会产生很多程序集,大量的程序集调用会造成程序非常慢。

举个栗子:

如果编译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++)
            {
                //如果调用100次,使用下面方式就会创建很多程序集,性能很低
                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文件未修改,最后只有一个程序集。

关于Razor中的cacheName的问题

标签:

原文地址:http://www.cnblogs.com/sean100/p/4558686.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!