【收集】C#一些基础的面试题
C# 中 Struct 與 Class 的區別,以及兩者的適用場合
class 是引用類型,structs是值類型,class分配在堆上,struct分配在棧里?
既然class是引用類型,class可以設為null。但是我們不能將struct設為null,因為它是值類型。
?
你使用的是一個對class實例的引用。而你使用的不是對一個struct的引用。(而是直接使用它們)
當我們將class作為參數傳給一個方法,我們傳遞的是一個引用。struct傳遞的是值而非引用。
?
struct 不能被繼承,class 可以被繼承
class支持繼承和多態,Struct不支持. 注意:但是Struct 可以和類一樣實現接口
既然Struct不支持繼承,其成員不能以protected 或Protected Internal 修飾
struct 默認的訪問權限是public,而class 默認的訪問權限是private.
?
struct總是有默認的構造函數,即使是重載默認構造函數仍然會保留。這是因為Struct的構造函數是由編譯器自動生成的,但是如果重載構造函數,必需對struct中的變量全部初始化。并且Struct的用途是那些描述輕量級的對象,例如Line,Point等,并且效率比較高。class在沒有重載構造函數時有默認的無參數構造函數,但是一被重載些默認構造函數將被覆蓋。
?
struct的new和class的new是不同的。struct的new就是執行一下構造函數創建一個新實例再對所有的字段進行Copy。而class則是在堆上分配一塊內存然后再執行構造函數,struct的內存并不是在new的時候分配的,而是在定義的時候分配
?
Class比較適合大的和復雜的數據,Struct適用于作為經常使用的一些數據組合成的新類型。
適用場合:Struct有性能優勢,Class有面向對象的擴展優勢。
用于底層數據存儲的類型設計為Struct類型,將用于定義應用程序行為的類型設計為Class。如果對類型將來的應用情況不能確定,應該使用Class。
?
C#中抽象類和接口的區別
一、抽象類:
????? 抽象類是特殊的類,只是不能被實例化;除此以外,具有類的其他特性;重要的是抽象類可以包括抽象方法,這是普通類所不能的。抽象方法只能聲明于抽象類中,且不包含任何實現,派生類必須覆蓋它們。另外,抽象類可以派生自一個抽象類,可以覆蓋基類的抽象方法也可以不覆蓋,如果不覆蓋,則其派生類必須覆蓋它們。
二、接口:
????? 接口是引用類型的,類似于類,和抽象類的相似之處有三點:
???????1、不能實例化;
?????? 2、包含未實現的方法聲明;
?????? 3、派生類必須實現未實現的方法,抽象類是抽象方法,接口則是所有成員(不僅是方法包括其他成員);
?????? 另外,接口有如下特性:
接口除了可以包含方法之外,還可以包含屬性、索引器、事件,而且這些成員都被定義為公有的。除此之外,不能包含任何其他的成員,例如:常量、域、構造函數、析構函數、靜態成員。一個類可以直接繼承多個接口,但只能直接繼承一個類(包括抽象類)。
三、抽象類和接口的區別:
????? 1.類是對對象的抽象,可以把抽象類理解為把類當作對象,抽象成的類叫做抽象類.而接口只是一個行為的規范或規定,微軟的自定義接口總是后帶able字段,證明其是表述一類類“我能做。。。”.抽象類更多的是定義在一系列緊密相關的類間,而接口大多數是關系疏松但都實現某一功能的類中.?
????? 2.接口基本上不具備繼承的任何具體特點,它僅僅承諾了能夠調用的方法;?????
??????3.一個類一次可以實現若干個接口,但是只能擴展一個父類 ? ??
????? 4.接口可以用于支持回調,而繼承并不具備這個特點. ? ??
????? 5.抽象類不能被密封。 ??
????? 6.抽象類實現的具體方法默認為虛的,但實現接口的類中的接口方法卻默認為非虛的,當然您也可以聲明為虛的.?
????? 7.(接口)與非抽象類類似,抽象類也必須為在該類的基類列表中列出的接口的所有成員提供它自己的實現。但是,允許抽象類將接口方法映射到抽象方法上。???
8.如果抽象類實現接口,則可以把接口中方法映射到抽象類中作為抽象方法而不必實現,而在抽象類的子類中實現接口中方法.
四、抽象類和接口的使用:
????? 1.?如果預計要創建組件的多個版本,則創建抽象類。抽象類提供簡單的方法來控制組件版本。
????? 2.如果創建的功能將在大范圍的全異對象間使用,則使用接口。如果要設計小而簡練的功能塊,則使用接口。
??????3.如果要設計大的功能單元,則使用抽象類.如果要在組件的所有實現間提供通用的已實現功能,則使用抽象類。???
????? 4.抽象類主要用于關系密切的對象;而接口適合為不相關的類提供通用功能。
?
sql優化-索引
http://database.ctocio.com.cn/tips/272/7588272.shtml?微軟的SQL SERVER提供了兩種索引:聚集索引(clustered index,也稱聚類索引、簇集索引)和非聚集索引(nonclustered index,也稱非聚類索引、非簇集索引)
?
其實,我們的漢語字典的正文本身就是一個聚集索引。比如,我們要查“安”字,就會很自然地翻開字典的前幾頁,因為“安”的拼音是“an”,而按照拼音排序漢字的字典是以英文字母“a”開頭并以“z”結尾的,那么“安”字就自然地排在字典的前部。如果您翻完了所有以“a”開頭的部分仍然找不到這個字,那么就說明您的字典中沒有這個字;同樣的,如果查“張”字,那您也會將您的字典翻到最后部分,因為“張”的拼音是“zhang”。也就是說,字典的正文部分本身就是一個目錄,您不需要再去查其他目錄來找到您需要找的內容。
我們把這種正文內容本身就是一種按照一定規則排列的目錄稱為“聚集索引”。
?
如果您認識某個字,您可以快速地從自典中查到這個字。但您也可能會遇到您不認識的字,不知道它的發音,這時候,您就不能按照剛才的方法找到您要查的字,而需要去根據“偏旁部首”查到您要找的字,然后根據這個字后的頁碼直接翻到某頁來找到您要找的字。但您結合“部首目錄”和“檢字表”而查到的字的排序并不是真正的正文的排序方法,比如您查“張”字,我們可以看到在查部首之后的檢字表中“張”的頁碼是672頁,檢字表中“張”的上面是“馳”字,但頁碼卻是63頁,“張”的下面是“弩”字,頁面是390頁。很顯然,這些字并不是真正的分別位于“張”字的上下方,現在您看到的連續的“馳、張、弩”三字實際上就是他們在非聚集索引中的排序,是字典正文中的字在非聚集索引中的映射。我們可以通過這種方式來找到您所需要的字,但它需要兩個過程,先找到目錄中的結果,然后再翻到您所需要的頁碼。
我們把這種目錄純粹是目錄,正文純粹是正文的排序方式稱為“非聚集索引”。
?
每個表只能有一個聚集索引,因為目錄只能按照一種方法進行排序。
?
下面的表總結了何時使用聚集索引或非聚集索引(很重要)。
| ?動作描述 | 使用聚集索引? | ?使用非聚集索引 |
| ?外鍵列 | ?應 | ? 應 |
| ?主鍵列 | ?應 | ?應 |
| ?列經常被分組排序(order by) | ?應 | ?應 |
| ?返回某范圍內的數據 | ?應 | ?不應 |
| ?小數目的不同值 | ?應 | ?不應 |
| ?大數目的不同值 | ?不應 | ?應 |
| ?頻繁更新的列 | 不應? | ?應 |
| ?頻繁修改索引列 | ?不應 | ?應 |
| ?一個或極少不同值 | ?不應 | ?不應 |
? 事實上,我們可以通過前面聚集索引和非聚集索引的定義的例子來理解上表。
例如返回某范圍內的數據一項。比如您的某個表有一個時間列,恰好您把聚合索引建立在了該列,這時您查詢2004年1月1日至2004年10月1日之間的全部數據時,這個速度就將是很快的,因為您的這本字典正文是按日期進行排序的,聚類索引只需要找到要檢索的所有數據中的開頭和結尾數據即可
總結
以上是生活随笔為你收集整理的【收集】C#一些基础的面试题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【收集】常用网络上的Webservice
- 下一篇: vb怎么调用oracle数据库连接,VB