Будет ли закрывать это выражение «использование» вокруг DataReader?

Я обычно пишу свойDataReader код как это:

try
{
    dr = cmd.ExecuteReader(CommandBehavior.SingleResult);
    while (dr.Read())
    {
        // Do stuff
    }
}
finally
{
    if (dr != null) { dr.Close(); }
}

Безопасно ли заменитьtry а такжеfinally только сusing блок вокругDataReaderтворение? Я удивляюсь, потому что во всех примерах Microsoft, которые я видел, они используют использование для соединения, но всегда явно вызываютClose() наDataReader.

Вот пример изПолучение данных с помощью DataReader (ADO.NET):

static void HasRows(SqlConnection connection)
{
    using (connection)
    {
        SqlCommand command = new SqlCommand(
          "SELECT CategoryID, CategoryName FROM Categories;",
          connection);
        connection.Open();

        SqlDataReader reader = command.ExecuteReader();

        if (reader.HasRows)
        {
            while (reader.Read())
            {
                Console.WriteLine("{0}\t{1}", reader.GetInt32(0),
                    reader.GetString(1));
            }
        }
        else
        {
            Console.WriteLine("No rows found.");
        }
        reader.Close();
    }
}

Ответы на вопрос(4)

Ваш ответ на вопрос