2

我遇到的有趣问题完全有道理。我有一个像这样的通用方法:

public TResult Run<TResult>(Func<SqlDataReader, TResult> resultDelegate)
{
   TResult result;

   using (SqlDataReader reader = command.ExecuteReader()) // command is SqlCommand with attached SqlConnection
   {
      result = resultsDelegate(reader);
   }

   // Some other unrelated code (but that's why result has a variable)

   return result;
}

在一种情况下,resultDelegate的返回类型 ( TResult) 是IEnumerable<object>。问题是Run由于延迟执行,该函数立即返回,处理 SqlDataReader。稍后在代码中,当我尝试通读结果时(委托所做的reader.Read(),我得到一个InvalidOperationException: Invalid attempt to call Read when reader is closed.

我很难找出解决这个问题的最佳方法。我知道我可以返回一个具体的列表,但如果可能的话,我想避免这种情况。我也可以在委托中移动 using 语句,但是再一次,如果我可以避免对每个委托都这样做,那就太好了。有任何想法吗?

4

1 回答 1

5

也许:

public TResult Run<TResult>(Func<SqlDataReader, TResult> resultDelegate)
{
   TResult result;

   using (SqlDataReader reader = command.ExecuteReader()) // command is SqlCommand with attached SqlConnection
   {
      result = resultsDelegate(reader);
      if (typeof(TResult) == typeof(IEnumerable<object>)) 
      {
         var enumerable = result as IEnumerable<object>;
         if (enumerable != null) 
         {
            result = enumerable.ToList();  
         }
      }
   }

   // Some other unrelated code (but that's why result has a variable)

   return result;

}
于 2010-10-22T19:32:59.660 回答