1.using指令。using + 命名空間名字,這樣可以在程式中直接用命令空間中的類型,而不必指定類型的詳細命名空間,類似於Java的import,這個功能也是最常用的,幾乎每個cs的程式都會用到。
例如:using System;
using System.Data;
2.using語句,定義一個範圍,在範圍結束時處理對象。
情境:
當在某個程式碼片段中使用了類的執行個體,而希望無論因為什麼原因,只要離開了這個程式碼片段就自動調用這個類執行個體的Dispose。
要達到這樣的目的,用try...catch來捕捉異常也是可以的,但用using也很方便
比如,
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using aClass = ConsoleApplication1.MyClass;
using bClass = ConsoleApplication2.MyClass;
namespace ConsoleApplication1
{
public
class MyClass
{
public
override
string ToString()
{
return "You are in ConsoleApplication1.MyClass";
}
}
class TestUsing
{
}
}
namespace ConsoleApplication2
{
class MyClass
{
public
override
string ToString()
{
return "You are in ConsoleApplication2.MyClass";
}
}
}
namespace TestUsing
{
using ConsoleApplication1;
using ConsoleApplication2;
class ClassTestUsing
{
static
void Main()
{
aClass my1 = new aClass();
Console.WriteLine(my1);
bClass my2 = new bClass();
Console.WriteLine(my2);
Console.WriteLine("ress any key");
Console.Read();
}
}
}
using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
dt.Load(sdr); //此處用到sdr對象
} //此處釋放sdr對象,並關閉connection對象串連
如
public
static DataTable GetTable(string sql, int executeTimeOut, string connStringName)
{
DataTable dtRet = new DataTable();
using (SqlConnection sc = new SqlConnection(connStringName))
{
using (SqlDataAdapter sqa = new SqlDataAdapter(sql, sc))
{
sqa.SelectCommand.CommandTimeout = executeTimeOut;
sqa.Fill(dtRet);
return dtRet;
}
}
}
在這段代碼中,sdr對象包含在小括弧中,說明當using下的這段代碼不管是執行成功或失敗,只要離開了這段代碼,會自動調用sdr對象的Dispose方法。CommandBehavior.CloseConnection的作用是當command對象釋放時,connection也跟著關閉。它跟下面這段代碼效果是一致的:
Try
conn.Open()
Return cmd.ExecuteNonQuery()
cmd.Parameters.Clear()
Catch ex As Exception
Return False
Finally
'關閉資料庫教程串連,銷毀cmd對象
If Not IsNothing(conn) Then
conn.Close()
conn = Nothing
End If
If Not IsNothing(cmd) Then
cmd.Dispose()
cmd = Nothing
End If
End Try