using 语句
- 提供可确保正确使用 IDisposable 对象的方便语法。
-
示例
下面的示例演示如何使用
using
语句。C#复制
using (var font1 = new Font("Arial", 10.0f)) { byte charset = font1.GdiCharSet; }
备注
File 和 Font 是访问非托管资源(本例中为文件句柄和设备上下文)的托管类型的示例。 有许多其他类别的非托管资源和封装这些资源的类库类型。 所有此类类型都必须实现 IDisposable 接口。
IDisposable
对象的生存期限于单个方法时,应在using
语句中声明并实例化它。using
语句按照正确的方式调用对象上的 Dispose方法,并(在按照前面所示方式使用它时)会导致在调用 Dispose 时对象自身处于范围之外。 在using
块中,对象是只读的并且无法进行修改或重新分配。using
语句可确保调用 Dispose,即使using
块中发生异常也是如此。 通过将对象放入try
块中,然后调用finally
块中的 Dispose,可以实现相同的结果;实际上,这就是编译器转换using
语句的方式。 前面的代码示例在编译时将扩展到以下代码(请注意,使用额外的大括号为对象创建有限范围):C#复制
{ var font1 = new Font("Arial", 10.0f); try { byte charset = font1.GdiCharSet; } finally { if (font1 != null) ((IDisposable)font1).Dispose(); } }
有关
try
-finally
语句的详细信息,请参阅 try-finally 主题。可在
using
语句中声明一个类型的多个实例,如下面的示例中所示:C#复制
using (Font font3 = new Font("Arial", 10.0f), font4 = new Font("Arial", 10.0f)) { // Use font3 and font4. }
可以实例化资源对象,然后将变量传递到
using
语句,但这不是最佳做法。 在这种情况下,控件退出using
块以后,对象保留在作用域中,但是可能没有访问其未托管资源的权限。 换而言之,它不再是完全初始化的。 如果尝试在using
块外部使用该对象,则可能导致引发异常。 因此,通常最好在using
语句中实例化该对象并将其范围限制在using
块中。C#复制
var font2 = new Font("Arial", 10.0f); using (font2) // not recommended { // use font2 } // font2 is still in scope // but the method call throws an exception float f = font2.GetHeight();
-