asp.net using的三種使用方法

來源:互聯網
上載者:User

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.