1. 程式人生 > >.NET 基礎知識

.NET 基礎知識

帶著問題去思考!大家好。

 

修飾符

修飾符有什麼作用呢?它是什麼東西呢?

首先修飾符有四種

  • private[ˈpraɪvət]   
  • protected [prə'tektɪd]  
  • internal [ɪnˈtɜːnl]
  • public [ˈpʌblɪk] 

他們的特效依次是:

private   修飾符用於設定類或類成員的訪問許可權僅為所屬類的內部, private也被稱為私有修飾符。某些時候需要訪問私有類成員時,可通過 get 和 set 訪問器讀取或修改。

protected    修飾符用於設定類或類成員的訪問許可權僅為所屬類及子類的內部.

internal     修飾符修飾的類或類成員的訪問許可權為同一程式集內部,C# 預設的類訪問修飾符即為 internal。

面向物件程式設計的特徵之一就是封裝性, 而類就是封裝性的典型體現。在生活中,人們不需要知道電器的內部構造, 但是能很容易地使用電器, 這就是封裝性。 在專案中需要編寫很多功能類, 在程式執行時只需要使用類所提供的功能, 大部分類內部的程式碼 實現 需要封裝, 拒絕外部訪問。 這樣大大增加了類的內部程式碼 安全性和穩定性, 同時多個功能類之間也減少了互相干擾的可能。 訪問許可權修飾符即可將類及類的成員劃分多種 安全 級別, 根據 不同 需要 設定 訪問 許可權。 internal 和 public 訪問 修飾符是需要謹慎選擇的, 多數情況下應該儘量使用 internal 訪問修飾符。 還有 一種 訪問 修飾 符,

即 protected internal 修飾符, 可在子類中或同一程式集內被訪問。如果要宣告成員只能被同一 程式集內的派生(子類)訪問, 則應首先設定 所屬類為 internal,成員設定 為 protected。

方法的過載和重寫(override)

 過載和重寫的區別?

過載是方法的名稱相同, 函式簽名不同, 進行多次過載以適應不同的需要。 而重寫( override) 是進行基類中函式的擴充套件或改寫

值型別和引用型別

他們的區別是什麼?

值型別包含資料,引用型別變數只包含資料的記憶體地址。值型別只要離開其定義的作用域,將從記憶體中消除,而引用型別引用的物件一直存留在託管堆

介面和抽象類 

interface abstract [ˈæbstrækt] 

介面和抽象類是什麼?為什麼他們一起說?他們的共同點是什麼?又有什麼區別?

介面和抽象類非常相似,兩者都無法例項化,並且未實現部分都由派生類實現

區別:

抽象類 介面
只能派生類 派生類和結構,
派生類(derived class)也可以是抽象類,即抽象類成員在派生類中不一定被完全實現 要求派生類或結構必須完全實現其成員。
可以包含已經實現的成員,可以包含欄位 只包含未實現的成員,不能包含欄位。並且介面所含成員必須為public訪問級別。
類只能繼承一個抽象類 類可以繼承實現多個介面。

抽象類的類體中可包含試的成員,而未實現的成員為抽象成員。抽象方法或屬性本事就是隱性的[1]virtual [ˈvɜːtʃuəl].所以派生類實現抽象方法或屬性必須使用override關鍵字。

繼承抽象類的類如果 沒有完全實現抽象成員, 仍然只能是抽象類, 即派生的非抽象類必須完全實現抽象成員。 抽象類也可以實現介面, 這時抽象類必須實現所有的介面成員, 也可以將繼承的介面成員對映至抽象成員, 並由其派生類來實現。 說明: 抽象類的抽象成員不能使用 [1]virtual [ˈvɜːtʃuəl].或 static 修飾。

this和base有什麼作用?

this關鍵字用於引用類的當前 例項。 base 關鍵字用於派生類訪問基類成員。

堆和棧

棧指堆疊,堆指託管堆。兩者是程式可用記憶體的兩個區域,其中堆疊可用於儲存非例項成員的值型別資料, 以及引用型別的變數( 用於儲存引用型別例項), 而託管堆可用於 儲存引用型別例項的資料及相關資訊。不但儲存內容不同, 堆疊和託管堆的記憶體分配方式也不同。

 

   
int i = 0;    
int j = 1;    
Cow a = new Cow();   
Cow b = new Cow();     
Cow c = b; 
int ii = i; 
ii = 10;
int jj = j;

 

  

 

 

 

 

  1.  一般我們不需要管記憶體管理,因為有CLR.
  2. 堆疊和託管堆用於儲存. NET程式中的值型別和引用 型別 資料。 程式程式碼中宣告一個值型別變數 時, CLR 直接在堆疊中分配可用的的空間給該變數。 當代碼中宣告一個引用 型別 的 變數 時, 該變數只是一個指向 null 的 空 引用, 並且該用同樣儲存在堆疊上。
  3. 如果使用 new 運算子 建立 引用 型別 的 例項 時, CLR 將在託管堆中分配可用的空間給該例項, 這個 例項 無法 直接 訪問。一般 將 用 new 建立 的 例項 賦值 給 某個 引用 型別的變數 時, 該變數將儲存指向這個例項的記憶體 地址。 由此可知, 堆疊和託管堆是程式 可用記憶體空間的兩個 區域。 堆疊可用於儲存非物件的值型別資料和引用類 例項 的地址引用, 而託管堆可用於儲存 由 new 建立 的 引用型別例項, 引用 型別 變數 可 儲存 例項 的 地址 引用, 以達到訪問例項的目的。
  4. 不過堆疊的資料清除和託管堆的資料清除有很大的不同, 堆疊的值型別資料在超出作用域時將被清除。 而 託管 堆 中的 例項 只有 在 沒有 被 任何 變數 引用 時, 才可 能在 未來 某個 時間 被 清除, 託管堆的資料清除 交給垃圾收集器( GC) 完成。

 

 

 

【1】:

 

 

 

 

 

 

 

 

 

 

 

 

 

&n