Согласно MSDN Library
using Statement (C# Reference)<br>
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
и его область видимости, а также когда, где и зачем его использовать.Спасибо ..