2009-11-10 61 views
5

在我最近使用Asp.net Mvc 2的项目中,我们发现DisplayFor存在性能问题。我不太确定这是真实问题还是我错过了什么?Asp.net Mvc 2 DisplayFor性能问题?

我希望一些Asp.net Mvc Guru可以给我解释一下。 :)

型号。

public class Customer 
{ 
    public int CustomerId { get; set; } 
    public string Name { get; set; } 
    public string Address { get; set; } 
    public string EmailAddress { get; set; } 

    public static IEnumerable<Customer> GetCustomers() 
    {    
     for (int i = 0; i < 1000; i++) 
     { 
      var cust = new Customer() 
      { 
       CustomerId = i + 1, 
       Name = "Name - " + (i + 1), 
       Address = "Somewhere in the Earth...", 
       EmailAddress = "customerABC" 
      }; 

      yield return cust; 
     } 
    } 
} 

控制器

public ActionResult V1() 
    {    
     return View(Customer.GetCustomers()); 
    } 

    public ActionResult V2() 
    { 
     return View(Customer.GetCustomers()); 
    } 

V1(其中有性能问题)

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<IEnumerable<Customer>>" %> 

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server"> 
    V1 
</asp:Content> 

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"> 

    <h2>V1</h2> 
    <table> 
    <%foreach (var cust in this.Model) 
     {%> 
     <%= Html.DisplayFor(m => cust) %> 
     <%} %> 
    </table> 
</asp:Content> 

而且模板是

<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<Customer>" %> 
<tr> 
    <td><%= this.Model.CustomerId %></td> 
    <td><%= this.Model.Name %></td> 
    <td><%= this.Model.Address %></td> 
    <td><%= this.Model.EmailAddress %></td>  
</tr> 

V2(无性能问题)

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<IEnumerable<Customer>>" %> 

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server"> 
    V2 
</asp:Content> 
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"> 
    <h2>V2</h2> 
    <table> 
    <%foreach (var cust in this.Model) 
     {%> 
     <tr> 
      <td><%= cust.CustomerId%></td> 
      <td><%= cust.Name%></td> 
      <td><%= cust.Address%></td> 
      <td><%= cust.EmailAddress%></td>  
     </tr> 
     <%} %> 
     </table> 
</asp:Content> 

我可以很容易地看到V1和V2之间的性能差异。

编辑:当我部署到我的本地IIS 7(与发行版),它(V1)变得非常快。问题解决了,但我仍然想知道原因。 :)

谢谢,
梭萌

回答

0

的问题是,DisplayFor()使用,其被编译并在运行时执行的lambda表达式。

因此,V1中的性能差异可以归因于该“中间”编译步骤。

V2只是一个不需要任何编译的属性访问。

我在这里猜测,但我想象IIS7足够聪明,可以保存视图(和编译的lambda表达式)的缓存副本以供将来重用,这意味着后续渲染时间将与V1在IIS 6中。

+0

的假设IIS7是这里的关键因素,是不正确的。请参阅Levi的答案以获取正确的信息。 – thomasjo

+0

答案被接受后IIS7被提及,所以我不能删除它:( – Codebrain