.net程式設計師面試寶典

1.string str=new string("a")和string str = "a"有什麼區別?

string str = "a"; 這個只是一個引用,記憶體中如果有“a"的話,str就指向它,如果沒有才創建如後還用到"a"這個字元串的話並且是這樣用: string str1 = "a"; string str2 = "a"; string str2 = "a"; 這4個變數都共享一個字元串"a" 而string str = new string("a");是根據"a"這個string對象再次構造一個string對象,將新構造出來的string對象的引用賦給str

2.判斷字元串變數str是否為空的一下三種方法哪個性能更優

a、str=="";b、str==string.empty;c、str.length==0;?答案是c;

3.string與string的區別

string、int是c#定義的類型,而string、int32是.net類型即是cts類型; string 是 .net 框架中 system.string 的別名。string在編譯的時候會轉化為string類

4.虛方法(virtual )和抽象方法(abstract)的區別?

1:抽象方法僅有聲明,而沒有任何實現,如abstract somemethod();,虛方法卻不能如此

virtual用於修飾方法、屬性、索引器或事件聲明,並使它們可以在派生類中被重寫。

2:子類繼承父類,可以對父類中的虛方法進行重寫、覆蓋、不處理三種處理(見5),對抽象方法卻必須實現

5.子類對父類中虛方法的處理有重寫(override)和覆蓋(new),請說明它們的區別?

有父類parentclass和子類childclass、以及父類的虛方法virtualmethod。有如下程式段:

parentclass pc = new childclass();pc.virtualmethod(...);

如果子類是重寫(override)父類的virtualmethod,則上面的第二行語句將調用子類的該方法

如果子類是覆蓋(new)父類的virtualmethod,則上面的第二行語句將調用父類的該方法

6.抽象類(abstract)和接口(interface)的區別

抽象類可以有自己的實現,接口卻僅有聲明,可以有自己的靜態數據欄位;

java和c#中可以實現多個接口,卻只能繼承一個抽象類(或者非抽象類)(單繼承,和c++的多繼承不同);

7.填空:

(1)面向對象的語言具有 繼承性、多態性、封裝性。

(2)能用foreach遍歷訪問的對象需要實現 _ienumerable___接口或聲明_getenumerator_方法的類型。

(3)列舉ado.net中的五個主要對象

connection,command,datareader,dataadapter,dataset

connection 連線對象

command 命令對象,指示要執行的命令和存儲過程!

datareader是一個向前的唯讀的數據流。

dataadapter是功能強大的適陪器,支持增刪改查的功能

dataset是一個數據級對象,相當與記憶體中的一張表或多張表

8.不定項選擇:

(1) 以下敘述正確的是:bc

a. 接口中可以有虛方法。 b. 一個類可以實現多個接口。

c. 接口不能被實例化。 d. 接口中可以包含已實現的方法。

(2) 從資料庫讀取記錄,你可能用到的方法有: bcd

a. executenonquery b. executescalar c. fill d. executereader

9.簡述 private、 protected、 public、 internal 修飾符的訪問許可權。

a.private:關鍵字是一個成員訪問修飾符。私有訪問是允許的最低訪問級別。私有成員只有在聲明它們的類和結構體中才是可訪問的, 同一體中的嵌套類型也可以訪問那些私有成員

b.protected 關鍵字是一個成員訪問修飾符。受保護成員在它的類中可訪問並且可由派生類訪問。有關 protected 與其他訪問修飾符的比較,請參見可訪問性級別,只有在通過派生類類型發生訪問時,基類的受保護成員在派生類中才是可訪問的

c.internal關鍵字是類型和類型成員的訪問修飾符。只有在同一程式集的檔案中,內部類型或成員才是可訪問的

d protected internal 它可以看作是protected與internal的並集,意思是:如果是繼承關係,無論在不在同一程式集裡都能訪問;如果不是繼承關係,那么只能在同一程式集內訪問。

e.public具有最高級別的訪問許可權,對訪問成員沒有限制。

10.寫出一條sql語句:取出表a中第31到第40記錄(sqlserver, 以自動增長的id作為主鍵, 注意:id

可能不是連續的。)