![](/img/trans.png)
[英]Slow Visual Studio Performance when debugging multithreaded WPF application
[英]Automapper performance issue only when debugging in Visual Studio
在WPF应用程序中,我正在使用AutoMapper将实体映射到域对象。
对于一个特定的映射,在运行带有调试(F5)而不运行(CTRL + F5)的应用程序时,我发现运行速度大大降低。 如果不调试,此映射将花费不到1秒的时间,但是如果进行调试,则需要花费约14秒的时间。
域对象(为简便起见简化):
public class CompanyModel : UpdateableModel
{
public CompanyModel() : this(true){}
public CompanyModel(bool isNewModel) : base(isNewModel)
{
Projects = new ObservableCollectionEx<ProjectModel>();
Projects.ItemPropertyChanged += (sender, args) => OnPropertyChanged("Projects");
}
public int? Id { get; set;}
public string Name { get; set; }
public string CompanyXref { get; set; }
public bool IsActive { get; set; }
public ObservableCollectionEx<ProjectModel> Projects { get; set;}
public DateTime? DateUpdated { get; set;}
}
public class ProjectModel : UpdateableModel
{
public ProjectModel() : this(true){}
public ProjectModel(bool isNewModel) : base(isNewModel)
{
Tasks = new ObservableCollectionEx<ProjectTaskModel>();
SetPropertyDefault(() => StartDate, DateTime.Today);
SetPropertyDefault(() => EndDate, DateTime.Today);
// ReSharper disable once ExplicitCallerInfoArgument
Tasks.ItemPropertyChanged += (sender, args) => OnPropertyChanged("Tasks");
}
public int? Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public DateTime StartDate { get; set; }
public DateTime EndDate { get; set; }
public string BillingCurrency { get; set; }
public string ExternalXref { get; set; }
public bool IsChargeable { get; set; }
public bool IsActive { get; set; }
public int TimeTypeId { get; set; }
public ObservableCollectionEx<ProjectTaskModel> Tasks { get; set;}
public DateTime? DateUpdated { get; set; }
}
public class ProjectTaskModel : UpdateableModel
{
public ProjectTaskModel() : this(true){}
public ProjectTaskModel(bool isNewModel) : base(isNewModel)
{
SetPropertyDefault(() => StartDate, DateTime.Today);
SetPropertyDefault(() => EndDate, DateTime.Today);
}
public int? Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public DateTime StartDate { get; set; }
public DateTime EndDate { get; set; }
public string ExternalXref { get; set; }
public bool IsActive { get; set; }
public DateTime? DateUpdated { get; set; }
}
实体:
public class CompanyEntity : BaseEntity
{
public virtual string CompanyName { get; set; }
public virtual string CompanyXref { get; set; }
public virtual bool IsActive { get; set; }
public virtual IList<ProjectEntity> Projects { get; set; }
public virtual DateTime? DateUpdated { get; set; }
}
public class ProjectEntity : BaseEntity
{
public virtual string ProjectName { get; set; }
public virtual string Description { get; set; }
public virtual DateTime StartDate { get; set; }
public virtual DateTime EndDate { get; set; }
public virtual string ExternalXref { get; set; }
public virtual bool IsChargeable { get; set; }
public virtual bool IsActive { get; set; }
public virtual int TimeTypeId { get; set; }
public virtual string CurrencyId { get; set; }
public virtual CompanyEntity ClientCompany { get; set; }
public virtual DateTime? DateUpdated { get; set; }
public virtual IList<ProjectTaskEntity> Tasks { get; set; }
}
public class ProjectTaskEntity : BaseEntity
{
public virtual string ProjectTaskName { get; set; }
public virtual string Description { get; set; }
public virtual DateTime StartDate { get; set; }
public virtual DateTime EndDate { get; set; }
public virtual string ExternalXref { get; set; }
public virtual bool IsActive { get; set; }
public virtual DateTime? DateUpdated { get; set; }
public virtual ProjectEntity Project { get; set; }
}
最后,映射,当前已显式映射所有属性:
CreateMap<CompanyEntity, CompanyModel>()
.ConstructUsing((CompanyEntity src) => new CompanyModel(false))
.MapMember(dest => dest.Id, src => src.Id)
.MapMember(dest => dest.Name, src => src.CompanyName)
.MapMember(dest => dest.CompanyXref, src => src.CompanyXref)
.MapMember(dest => dest.IsActive, src => src.IsActive)
.MapMember(dest => dest.Projects, src => src.Projects)
.IgnoreMember(dest => dest.State);
CreateMap<ProjectEntity, ProjectModel>()
.ConstructUsing((ProjectEntity src) => new ProjectModel(false))
.MapMember(dest => dest.Id, src => src.Id)
.MapMember(dest => dest.Name, src => src.ProjectName)
.MapMember(dest => dest.Description, src => src.Description)
.MapMember(dest => dest.BillingCurrency, src => src.CurrencyId)
.MapMember(dest => dest.StartDate, src => src.StartDate)
.MapMember(dest => dest.EndDate, src => src.EndDate)
.MapMember(dest => dest.ExternalXref, src => src.ExternalXref)
.MapMember(dest => dest.IsActive, src => src.IsActive)
.MapMember(dest => dest.IsChargeable, src => src.IsChargeable)
.MapMember(dest => dest.Tasks, src => src.Tasks)
.MapMember(dest => dest.TimeTypeId, src => src.TimeTypeId)
.IgnoreMember(dest => dest.State);
CreateMap<ProjectTaskEntity, ProjectTaskModel>()
.ConstructUsing((ProjectTaskEntity src) => new ProjectTaskModel(false))
.MapMember(dest => dest.Id, src => src.Id)
.MapMember(dest => dest.Name, src => src.ProjectTaskName)
.MapMember(dest => dest.Description, src => src.Description)
.MapMember(dest => dest.StartDate, src => src.StartDate)
.MapMember(dest => dest.EndDate, src => src.EndDate)
.MapMember(dest => dest.ExternalXref, src => src.ExternalXref)
.MapMember(dest => dest.IsActive, src => src.IsActive)
.IgnoreMember(dest => dest.State);
执行映射时,有16个公司,总共122个项目,并且每个项目当前只有一个任务。
我确实尝试忽略了映射上的各种属性,而这似乎是导致此问题的项目级别的Tasks集合。 忽略它,映射将花费2秒而不是14秒。
关于Visual Studio如何托管应用程序进行调试,这可能会导致此性能问题吗?
您可以下载替代的CSharp IDE,在其中以调试模式运行它,看看是否存在差异。 SharpDev是一个非常好的开源IDE,它支持C#项目。
http://www.icsharpcode.net/OpenSource/SD/Download/
至少这是一种有趣且简单的尝试替代方法。 SharpDev还内置有代码分析器,可以指示问题所在。
祝好运。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.