.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) 完成。

 Sealed修飾符

 sealed [sild]

密封類一般情況下的使用方法和其他類一樣,只是無法被繼承,密封類可用於單一功能的實現,防止被意外地繼承。

sealed修飾符實例方法和屬性,必須和override一起使用。

靜態類和靜態成員

當類中某些成員不需要創建實例實現,可將其聲明為靜態類成員。靜態成員訪問類名而非對象名,this 關鍵字也無法訪問靜態成員時直接引用,這些成員可用作該類的多個對象共享數據。

靜態類無法new創建對象,所以不能編寫構造函數。

 

【1】:

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM