Are there any side effects of returning from inside a using() statement?

前端 未结 5 1336
一向
一向 2021-01-31 07:02

Returning a method value from inside a using statement that gets a DataContext seems to always work fine, like this:

public sta         


        
相关标签:
5条回答
  • 2021-01-31 07:10

    No, I think it's clearer this way. Don't worry, Dispose will still be called "on the way out" - and only after the return value is fully evaluated. If an exception is thrown at any point (including evaluating the return value) Dispose will still be called too.

    While you certainly could take the longer route, it's two extra lines that just add cruft and extra context to keep track of (mentally). In fact, you don't really need the extra local variable - although it can be handy in terms of debugging. You could just have:

    public static Transaction GetMostRecentTransaction(int singleId)
    {
        using (var db = new DataClasses1DataContext())
        {
            return (from t in db.Transactions
                    orderby t.WhenCreated descending
                    where t.Id == singleId
                    select t).SingleOrDefault();
        }
    }
    

    Indeed, I might even be tempted to use dot notation, and put the Where condition within the SingleOrDefault:

    public static Transaction GetMostRecentTransaction(int singleId)
    {
        using (var db = new DataClasses1DataContext())
        {
            return db.Transactions.OrderByDescending(t => t.WhenCreated)
                                  .SingleOrDefault(t => t.Id == singleId);
        }
    }
    
    0 讨论(0)
  • 2021-01-31 07:14

    Yes, there can be a side effect. For example, if you use the same technique in ASP.NET MVC Action method, you will get the following error: "The ObjectContext instance has been disposed and can no longer be used for operations that require a connection"

    public ActionResult GetMostRecentTransaction(int singleId)
    {
        using (var db = new DataClasses1DataContext())
        {
            var transaction = (from t in db.Transactions
                                  orderby t.WhenCreated descending
                                  where t.Id == singleId
                                  select t).SingleOrDefault();
            return PartialView("_transactionPartial", transaction);
        }
    }
    
    0 讨论(0)
  • 2021-01-31 07:15

    There are no side effects of returning from inside a using() statement.

    Whether it makes the most readable code is another discussion.

    0 讨论(0)
  • 2021-01-31 07:18

    Have a look at this

    Understanding the 'using' statement in C#

    The CLR converts your code into MSIL. And the using statement gets translated into a try and finally block. This is how the using statement is represented in IL. A using statement is translated into three parts: acquisition, usage, and disposal. The resource is first acquired, then the usage is enclosed in a try statement with a finally clause. The object then gets disposed in the finally clause.

    0 讨论(0)
  • 2021-01-31 07:27

    I think, it's all the same. There's nothing bad in the code. The .NET framework wouldn't care where the object is created. The thing that matters is whether it is referenced or not.

    0 讨论(0)
提交回复
热议问题