A colocação de uma declaração "using" em torno de um DataReader a fechará?

Eu costumo escrever meuDataReader código como este:

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

É seguro substituir otry efinally com apenas umusing bloquear em torno doDataReadercriação? A razão pela qual me pergunto é porque, em todos os exemplos da Microsoft, vi que eles usam um uso para a conexão, mas sempre chamam explicitamenteClose() noDataReader.

Heres é um exemplo deRecuperando dados usando um 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();
    }
}

questionAnswers(4)

yourAnswerToTheQuestion