Согласно Библиотека MSDN
using Statement (C# Reference)
Defines a scope, outside of which an object or objects will be disposed.
Но я получил этот код, размещенный здесь у какого-то пользователя, и я смутился об этом: (см. мой комментарий к коду)
using (OleDBConnection connection = new OleDBConnection(connectiongString))
{
if (connection.State != ConnectionState.Open)
connection.Open();
string sql = "INSERT INTO Student (Id, Name) VALUES (@idParameter, @nameParameter)";
using (OleDBCommand command = connection.CreateCommand())
{
command.CommandText = sql;
command.CommandType = CommandType.Text;
OleDBParameter idParameter = command.CreateParameter();
idParameter.DbType = System.Int32;
idParameter.Direction = Parameterdirection.Input;
idParameter.Name = "@idParameter";
idParameter.Value = studentId;
OleDBParameter nameParameter = command.CreateParameter();
try
{
command.ExecuteNonQuery();
}
finally
{
// Is it still necessary to dispose these objects here?
command.Dispose();
connection.Dispose();
}
}
}
В приведенном выше коде используется ли оператор using
правильно?
Я смущен, может кто-нибудь объяснить, как использовать оператор using
и его область охвата и когда, где и зачем его использовать. Спасибо..