1. 程式人生 > >c#靜態方法和非靜態方法區別

c#靜態方法和非靜態方法區別

特殊 靜態成員 pan 們的 gpo ase sna eth key

c#靜態方法和非靜態方法區別 C#的類中可以包含兩種方法:C#靜態方法與非靜態方法。那麽他們的定義有什麽不同呢?他們在使用上會有什麽不同呢?讓我們來看看最直觀的差別:使用了static 修飾符的方法為靜態方法,反之則是非靜態方法。

比較一、C#靜態成員:

靜態成員屬於類所有,非靜態成員屬於類的實例所有。

每創建一個類的實例,都會在內存中為非靜態成員新分配一塊存儲;靜態成員屬於類所有,為各個類的實例所公用,無論類創建了多少實例,類的靜態成員在內存中只占同一塊區域。

比較二、C#靜態方法

C#靜態方法屬於類所有,類實例化前即可使用。

非靜態方法可以訪問類中的任何成員,靜態方法只能訪問類中的靜態成員。因為靜態方法在類實例化前就可以使用,而類中的非靜態變量必須在實例化之後才能分配內存,這樣,C#靜態方法調用時無法判斷非靜態變量使用的內存地址。所以無法使用。而靜態變量的地址對類來說是固定的,故可以使用。

比較三、C#靜態方法是一種特殊的成員方法

它不屬於類的某一個具體的實例,而是屬於類本身。所以對靜態方法不需要首先創建一個類的實例,而是采用類名.靜態方法的格式 。

static內部只能出現static變量和其他static方法!而且static方法中還不能使用this....等關鍵字..因為它是屬於整個類!

靜態方法效率上要比實例化高,靜態方法的缺點是不自動進行銷毀,而實例化的則可以做銷毀。

靜態方法和靜態變量創建後始終使用同一塊內存,而使用實例的方式會創建多個內存。

比較四、C#靜態方法中獲取類的名稱

靜態方法中用:

string className = System.Reflection.MethodBase. GetCurrentMethod().ReflectedType.FullName;

非靜態方法中還可以用:

string className = this.GetType().FullName;
使用靜態得準則就是:1.保證不會產生並發。2. 在方便快捷和開發難度上做一個衡量

c#靜態方法和非靜態方法區別