2010 .NET面試題整理之基礎篇
開篇語:對于已有工作經驗的朋友,也許面試題已顯得不怎么重要,但是如果你應聘的還僅僅是個普通的程序員,相信在很多的公司都還是會先拿出一套面試題,可能對整個面試影響不大,但做好面試題無疑會贏得第一個好的印象,特別對于那些缺少項目經驗的應屆畢業生。很多時候,在看這些面試題的時候,是否有感過曾經那些一個個不起眼的小程序題所針對的問題正是自己在項目中所犯的錯誤?是否會發現,原來還有這么多東西自己都還從未去想過?趁自己這次重新找工作之際,對常見面試題進行進行一次重新整理,與大家共同學習!本貼將會進行不斷完善和繼續更新,有些答案可能并不完全正確,希望能得到大家的指正。
接下來還將整理出:數據庫篇、算法篇、設計模式篇
1、什么是面向對象
面向對象OO = 面向對象的分析OOA + 面向對象的設計OOD + 面向對象的編程OOP;
通俗的解釋就是萬物皆對象,把所有的事物都看作一個個可以獨立的對象(單元),它們可以自己完成自己的功能,而不是像C那樣分成一個個函數;
現在純正的OO語言主要是java和C#,C++也支持OO,C是面向過程的。
2、簡述 private、 protected、 public、 internal 修飾符的訪問權限。
private : 私有成員, 在類的內部才可以訪問。
protected : 保護成員,該類內部和繼承類中可以訪問。
public : 公共成員,完全公開,沒有訪問限制。
internal: 當前程序集內可以訪問。
3、ADO.NET中的五個主要對象
Connection:主要是開啟程序和數據庫之間的連結。沒有利用連結對象將數據庫打開,是無法從數據庫中取得數據的。這個物件在ADO.NET 的最底層,我們可以自己產生這個對象,或是由其它的對象自動產生。
Command:主要可以用來對數據庫發出一些指令,例如可以對數據庫下達查詢、新增、修改、刪除數據等指令,以及呼叫存在數據庫中的預存程序等。這個對象是架構在Connection 對象上,也就是Command 對象是透過連結到數據源。
DataAdapter:主要是在數據源以及DataSet 之間執行數據傳輸的工作,它可以透過Command 對象下達命令后,并將取得的數據放入DataSet 對象中。這個對象是架構在Command對象上,并提供了許多配合DataSet 使用的功能。
DataSet:這個對象可以視為一個暫存區(Cache),可以把從數據庫中所查詢到的數據保留起來,甚至可以將整個數據庫顯示出來。DataSet 的能力不只是可以儲存多個Table 而已,還可以透過DataAdapter對象取得一些例如主鍵等的數據表結構,并可以記錄數據表間的關聯。DataSet 對象可以說是ADO.NET 中重量級的對象,這個對象架構在DataAdapter對象上,本身不具備和數據源溝通的能力;也就是說我們是將DataAdapter對象當做DataSet 對象以及數據源間傳輸數據的橋梁。
DataReader:當我們只需要循序的讀取數據而不需要其它操作時,可以使用DataReader 對象。DataReader對象只是一次一筆向下循序的讀取數據源中的數據,而且這些數據是只讀的,并不允許作其它的操作。因為DataReader 在讀取數據的時候限制了每次只讀取一筆,而且只能只讀,所以使用起來不但節省資源而且效率很好。使用DataReader 對象除了效率較好之外,因為不用把數據全部傳回,故可以降低網絡的負載。
ADO.NET 使用Connection 對象來連接數據庫,使用Command 或DataAdapter對象來執行SQL語句,并將執行的結果返回給DataReader 或 DataAdapter ,然后再使用取得的DataReader 或DataAdapter 對象操作數據結果。
4、列舉ASP.NET 頁面之間傳遞值的幾種方式。
1.使用QueryString, 如....?id=1; response. Redirect()....
2.使用Session變量
3.使用Server.Transfer
4.Cookie傳值
5.Application傳值
5、C#中的委托是什么?事件是不是一種委托?
委托可以把一個方法作為參數代入另一個方法。
委托可以理解為指向一個函數的引用。
是,是一種特殊的委托。
6、override與重載的區別
重載是方法的名稱相同。參數或參數類型不同,進行多次重載以適應不同的需要
Override 是進行基類中函數的重寫。為了適應需要。
7、描述一下C#中索引器的實現過程,是否只能根據數字進行索引?
不是。可以用任意類型。
8、三層架構通
常意義上的三層架構就是將整個業務應用劃分為:表現層(UI)、業務邏輯層(BLL)、數據訪問層(DAL)。
區分層次的目的即為了“高內聚,低耦合”的思想。
表現層(UI):通俗講就是展現給用戶的界面,即用戶在使用一個系統的時候的所見所得。
業務邏輯層(BLL):針對具體問題的操作,也可以說是對數據層的操作,對數據業務邏輯處理。
數據訪問層(DAL):該層所做事務直接操作數據庫,針對數據的增添、刪除、修改、更新、查找等每層之間是一種垂直的關系。
三層結構是N層結構的一種,一般來說,層次之間是向下依賴的,下層代碼未確定其接口(契約)前,上層代碼是無法開發的,下層代碼接口(契約)的變化將使上層的代碼一起變化。
優點: 分工明確,條理清晰,易于調試,而且具有可擴展性。
缺點: 增加成本。
9、MVC模式
MVC(Model View Controller)模型-視圖-控制器
MVC是典型的平行關系,沒有說誰在上誰在下的關系,模型負責業務領域的事情,視圖負責顯示的事情,控制器把數據讀取出來填充模型后把模型交給視圖去處理。而各種驗證什么的應該是在模型里處理了。它強制性的使應用程序的輸入、處理和輸出分開。MVC最大的好處是將邏輯和頁面分離。
10、什么是裝箱和拆箱?
裝箱:從值類型接口轉換到引用類型。
拆箱:從引用類型轉換到值類型。
11、什么叫應用程序域
一種邊界,它由公共語言運行庫圍繞同一應用程序范圍內創建的對象建立(即,從應用程序入口點開始,沿著對象激活的序列的任何位置)。
應用程序域有助于將在一個應用程序中創建的對象與在其他應用程序中創建的對象隔離,以使運行時行為可以預知。
在一個單獨的進程中可以存在多個應用程序域。應用程序域可以理解為一種輕量級進程。起到安全的作用。占用資源小。
12、CTS、CLS、CLR分別作何解釋
CTS:Common Type System 通用系統類型。
CLS:Common Language Specification 通用語言規范。
CLR:Common Language Runtime 公共語言運行庫。
13、在dotnet中類(class)與結構(struct)的異同?
Class可以被實例化,屬于引用類型,是分配在內存的堆上的
Struct屬于值類型,是分配在內存的棧上的。
14、堆和棧的區別?
棧是編譯期間就分配好的內存空間,因此你的代碼中必須就棧的大小有明確的定義;
堆是程序運行期間動態分配的內存空間,你可以根據程序的運行情況確定要分配的堆內存的大小。
15、能用foreach遍歷訪問的對象的要求
需要實現IEnumerable接口或聲明GetEnumerator方法的類型。
16、GC是什么? 為什么要有GC?
GC是垃圾收集器。程序員不用擔心內存管理,因為垃圾收集器會自動進行管理。
要請求垃圾收集,可以調用下面的方法之一: System.gc() Runtime.getRuntime().gc()
17、String s = new String("xyz");創建了幾個String Object?
兩個對象,一個是“xyx”,一個是指向“xyx”的引用對象。
18、值類型和引用類型的區別?
1.賦值方式不同:基于值類型的變量直接包含值。將一個值類型變量賦給另一個值類型變量時,將復制包含的值。引用類型變量的賦值只復制對對象的引用,而不復制對象本身。
2.值類型不可能派生出新的類型:所有的值類型均隱式派生自 System.ValueType。但與引用類型相同的是,結構也可以實現接口。
3.值類型不可能包含 null 值:然而,可空類型功能允許將 null 賦給值類型。
4.每種值類型均有一個隱式的默認構造函數來初始化該類型的默認值。
19、C#中的接口和類有什么異同。
不同點:
不能直接實例化接口。
接口不包含方法的實現。
接口可以多繼承,類只能單繼承。
類定義可在不同的源文件之間進行拆分。
相同點:
接口、類和結構都可以從多個接口繼承。
接口類似于抽象基類:繼承接口的任何非抽象類型都必須實現接口的所有成員。
接口和類都可以包含事件、索引器、方法和屬性。
20、abstract class和interface有什么區別?
相同點:
都不能被直接實例化,都可以通過繼承實現其抽象方法。
都是面向抽象編程的技術基礎,實現了諸多的設計模式。
不同點:
接口支持多繼承;抽象類不能實現多繼承。
接口只能定義抽象規則;抽象類既可以定義規則,還可能提供已實現的成員。
接口是一組行為規范;抽象類是一個不完全的類,著重族的概念。
接口可以用于支持回調(CallBack);抽象類不能實現回調,因為繼承不支持。
接口只包含方法(Method)、屬性(Property)、索引器(Index)、事件(Event)的簽名,但不能定義字段和包含實現的方法;
抽象類可以定義字段、屬性、包含有實現的方法。
接口可以作用于值類型(Struct)和引用類型(Class);抽象類只能作用于引用類型。例如,Struct就可以繼承接口,而不能繼承類。
21、sleep() 和 wait() 有什么區別?
sleep()方法是將當前線程掛起指定的時間。
wait()釋放對象上的鎖并阻塞當前線程,直到它重新獲取該鎖。
22、是否可以繼承String類?
String類是final類故不可以繼承。
23、try {}里有一個return語句,那么緊跟在這個try后的finally {}里的code會不會被執行,什么時候被執行,在return前還是后?
會執行,在return前執行。
24、new 關鍵字用法
new 運算符 用于創建對象和調用構造函數。
new 修飾符 用于向基類成員隱藏繼承成員。
new 約束 用于在泛型聲明中約束可能用作類型參數的參數的類型。
new實現多態
25、如何把一個Array復制到ArrayList里
實現1 string[] s ={ "111", "22222" }; ArrayList list = new ArrayList(); list.AddRange(s);
實現2 string[] s ={ "111", "22222" }; ArrayList list = new ArrayList(s);
26、DataGrid的Datasouse可以連接什么數據源
DataTable
DataView
DataSet
DataViewManager
任何實現IListSource接口的組件
任何實現IList接口的組件
27、描述線程與進程的區別?
1.線程(Thread)與進程(Process)二者都定義了某種邊界,不同的是進程定義的是應用程序與應用程序之間的邊界,不同的進程之間不能共享代碼和數據空間,而線程定義的是代碼執行堆棧和執行上下文的邊界。
2.一個進程可以包括若干個線程,同時創建多個線程來完成某項任務,便是多線程。而同一進程中的不同線程共享代碼和數據空間。用一個比喻來說,如果一個家庭代表一個進程,在家庭內部,各個成員就是線程,家庭中的每個成員都有義務對家庭的財富進行積累,同時也有權利對家庭財富進行消費,當面對一個任務的時候,家庭也可以派出幾個成員來協同完成,而家庭之外的人則沒有辦法直接消費不屬于自己家庭的財產。
28、什么是強類型,什么是弱類型?哪種更好些?為什么?
強類型是在編譯的時候就確定類型的數據,在執行時類型不能更改,而弱類型在執行的時候才會確定類型。
沒有好不好,二者各有好處,強類型安全,因為它事先已經確定好了,而且效率高。
一般用于編譯型編程語言,如c++,java,c#,pascal等,弱類型相比而言不安全,在運行的時候容易出現錯誤,但它靈活,多用于解釋型編程語言,如javascript,vb等
29、什么是反射?
程序集包含模塊,而模塊又包括類型,類型下有成員,反射就是管理程序集,模塊,類型的對象,它能夠動態的創建類型的實例,設置現有對象的類型或者獲取現有對象的類型,能調用類型的方法和訪問類型的字段屬性。它是在運行時創建和使用類型實例
30、DateTime是否可以為null?
不能,因為其為Struct類型,而結構屬于值類型,值類型不能為null,只有引用類型才能被賦值null
31、using() 語法有用嗎?什么是IDisposable?它是如何實現確定性終結的
有用,實現了IDisposiable的類在using中創建,using結束后會自定調用該對象的Dispose方法,釋放資源。不明白什么是確定性終結
32、Assembly.Load("foo.dll"); 這句話是否正確?
錯誤,正確的應該是Assembly.Load("foo"); 或者Assembly.LoadFrom("foo.dll");
33、Session有什么重大BUG,微軟提出了什么方法加以解決?
是iis中由于有進程回收機制,系統繁忙的話Session會丟失,可以用Sate server或SQL Server數據庫的方式存儲Session,不過這種方式比較慢,而且無法捕獲Session的END事件。
34、XML 與 HTML 的主要區別
1. XML是區分大小寫字母的,HTML不區分。
2. 在HTML中,如果上下文清楚地顯示出段落或者列表鍵在何處結尾,那么你可以省略
3. 在XML中,擁有單個標記而沒有匹配的結束標記的元素必須用一個 / 字符作為結尾。這樣分析器就知道不用 查找結束標記了。
4. 在XML中,屬性值必須分裝在引號中。在HTML中,引號是可用可不用的。
5. 在HTML中,可以擁有不帶值的屬性名。在XML中,所有的屬性都必須帶有相應的值。
35、重載與覆蓋的區別?
1.方法的覆蓋是子類和父類之間的關系,是垂直關系;方法的重載是同一個類中方法之間的關系,是水平關系
2.覆蓋只能由一個方法,或只能由一對方法產生關系;方法的重載是多個方法之間的關系。
3.覆蓋要求參數列表相同;重載要求參數列表不同。
4.覆蓋關系中,調用那個方法體,是根據對象的類型(對像對應存儲空間類型)來決定;重載關系,是根據調 用時的實參表與形參表來選擇方法體的。
36、請編程遍歷頁面上所有TextBox控件并給它賦值為string.Empty?
{
if (control is System.Windows.Forms.TextBox)
{
System.Windows.Forms.TextBox tb = (System.Windows.Forms.TextBox)control;
tb.Text = String.Empty;
}
}
37、根據線程安全的相關知識,分析以下代碼,當調用test方法時i>10時是否會引起死鎖?并說明理由。
{
lock (this)
{
if (i > 10)
{
i--;
test(i);
}
}
}
不會發生死鎖,(但有一點int是按值傳遞的,所以每次改變的都只是一個副本,因此不會出現死鎖。但如果把int換做一個object,那么死鎖會發生)
38、寫出程序的輸出結果
{
private string str = "Class1.str";
private int i = 0;
static void StringConvert(string str)
{
str = "string being converted.";
}
static void StringConvert(Class1 c)
{
c.str = "string being converted.";
}
static void Add(int i)
{
i++;
}
static void AddWithRef(ref int i)
{
i++;
}
static void Main()
{
int i1 = 10;
int i2 = 20;
string str = "str";
Class1 c = new Class1();
Add(i1);
AddWithRef(ref i2);
Add(c.i);
StringConvert(str);
StringConvert(c);
Console.WriteLine(i1);
Console.WriteLine(i2);
Console.WriteLine(c.i);
Console.WriteLine(str);
Console.WriteLine(c.str);
}
}
39、寫出程序的輸出結果
{
public A()
{
Console.WriteLine('A');
}
public virtual void Fun()
{
Console.WriteLine("A.Fun()");
}
}
public class B : A
{
public B()
{
Console.WriteLine('B');
}
public new void Fun()
{
Console.WriteLine("B.Fun()");
}
public static void Main()
{
A a = new B();
a.Fun();
}
}
40、寫出程序的輸出結果
{
public virtual void Fun1(int i)
{
Console.WriteLine(i);
}
public void Fun2(A a)
{
a.Fun1(1);
Fun1(5);
}
}
public class B : A
{
public override void Fun1(int i)
{
base.Fun1(i + 1);
}
public static void Main()
{
B b = new B();
A a = new A();
a.Fun2(b);
b.Fun2(a);
}
}
留言列表