0

我目前正在开发一个 ASP.NET MVC 应用程序,其中控制器使用存储库通过实体框架 ORM 访问数据。

下面是我的 ASP.NET MVC 控制器用于访问数据的接口和存储库的基本示例。

我遇到大量存储库留在 GC Gen2 内存中的情况,我想知道这是否是我的设计模式的结果?

对此的任何建议将不胜感激。我知道架构可以改进,这样的评论也会受到赞赏,但我的主要关注点是我的高内存使用率。

控制器

[SessionState(SessionStateBehavior.ReadOnly)]
public class GridCustomerServiceController : Controller
{
    private ICustomerServiceRepository _customerServiceRepository { get; set; }

    #region Constructor 

    public GridCustomerServiceController()
    {
        _customerServiceRepository = new CustomerServiceRepository();
    }

    #endregion Constructor

    #region Overrides
    protected override void Dispose(bool disposing)
    {
        this._customerServiceRepository.Dispose();

        base.Dispose(disposing);
    }
    #endregion Overrides

    [GridAction]
    [Authorize(Roles = "user")]
    public ActionResult _CustomerServicesSelect()
    {
            return View(new GridModel  
                {
                    Data =
                        (_customerServiceRepository.GetServicesByCustomerId(1))
                });

    }

界面

    using System.Linq;
    public interface ICustomerProductRepository
    {
        void Dispose();
        IQueryable<CustomerProduct> GetProductObjectsByCustomerId(int cid);
        void Add(Customer b);
        void Delete(Customer c);
        void Save();
    }

存储库

    public class CustomerProductRepository : ICustomerProductRepository
    {
        private myEntities db = new myEntities();

          #region Dispose Methods

        ~CustomerProductRepository()
        {
            Dispose(false);
        }

        public void Dispose()
        {
            Dispose(true);
            GC.SuppressFinalize(this);
        }

        protected virtual void Dispose(bool disposing)
        {
            if (db != null)
            {
                db.Dispose();
                db = null;
            }
        }

         #endregion Dispose Methods

        public void Delete(CustomerProduct c)
        {
            db.CustomerProducts.DeleteObject(c);
        }
        public void Save()
        {
            db.SaveChanges();
        }
        public void AddCustomerProduct(CustomerProduct b)
        {
            db.AddToCustomerProducts(b);
            db.SaveChanges();
        }
...
4

2 回答 2

2

您的接口可以从接口继承IDisposable以拥有该Dispose方法。样品:

public class CustomerProductRepository : ICustomerProductRepository, IDisposable 
{
   // the same code here...
}

有了这个,您还可以使用以下语法:

using (ICustomerProductRepository repo = new CustomerProductRepository())
{
   // use repository here...

} // auto dispose occurs here
于 2013-08-02T16:51:03.777 回答
1

正如 Felipe 所说,这里的关键是使用 IDisposable。GC 可以在运行时自动调用 IDisposable.Dispose,因此您不必担心。你也可以参考这里:1

于 2013-08-02T18:20:02.213 回答