面試問答大匯總.doc_第1頁
面試問答大匯總.doc_第2頁
面試問答大匯總.doc_第3頁
面試問答大匯總.doc_第4頁
面試問答大匯總.doc_第5頁
已閱讀5頁,還剩30頁未讀, 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

.net面試問答(大匯總) 用.net做B/S結構的系統,您是用幾層結構來開發,每一層之間的關系以及為什么要這樣分層? 答:從下至上分別為:數據訪問層、業務邏輯層(又或成為領域層)、表示層 數據訪問層:有時候也稱為是持久層,其功能主要是負責數據庫的訪問 業務邏輯層:是整個系統的核心,它與這個系統的業務(領域)有關 表示層:是系統的UI部分,負責使用者與整個系統的交互。 優點: 分工明確,條理清晰,易于調試,而且具有可擴展性。 缺點: 增加成本。 分層式結構究竟其優勢何在? 1、開發人員可以只關注整個結構中的其中某一層; 2、可以很容易的用新的實現來替換原有層次的實現; 3、可以降低層與層之間的依賴; 4、有利于標準化; 5、利于各層邏輯的復用。 概括來說,分層式設計可以達至如下目的:分散關注、松散耦合、邏輯復用、標準定義。 分層式結構也不可避免具有一些缺陷: 1、降低了系統的性能。這是不言而喻的。如果不采用分層式結構,很多業務可以直接造訪數據庫,以此獲取相應的數據,如今卻必須通過中間層來完成。 2、有時會導致級聯的修改。這種修改尤其體現在自上而下的方向。如果在表示層中需要增加一個功能,為保證其設計符合分層式結構,可能需要在相應的業務邏輯層和數據訪問層中都增加相應的代碼。 MVC模式 MVC(Model-View-Controller)把交互系統的組成分解成模型、視圖、控制器三種部件 mvc的優點: 1.通過把項目分成model view和controller,使得復雜項目更加容易維護。 2.沒有使用view state和服務器表單控件,可以更方便的控制應用程序的行為 3.應用程序通過controller來控制程序請求,可以提供豐富的url重寫。 4.對單元測試的支持更加出色 5.在團隊開發模式下表現更出眾 MVC的不足:(1)增加了系統結構和實現的復雜性。對于簡單的界面,嚴格遵循MVC,使模型、視圖與控制器分離,會增加結構的復雜性,并可能產生過多的更新操作,降低運行效率。 (2)視圖與控制器間的過于緊密的連接。視圖與控制器是相互分離,但確實聯系緊密的部件,視圖沒有控制器的存在,其應用是很有限的,反之亦然,這樣就妨礙了他們的獨立重用。 (3)視圖對模型數據的低效率訪問。依據模型操作接口的不同,視圖可能需要多次調用才能獲得足夠的顯示數據。對未變化數據的不必要的頻繁訪問,也將損害操作性能。 如何實現MVC模式,舉例說明! web/business/dataaccess列舉ASP.NET 頁面之間傳遞值的幾種方式。 1.使用QueryString, 如.?id=1; response. Redirect(). 2.使用Session變量 3.使用Server.Transfer 請說明在.net中常用的幾種頁面間傳遞參數的方法,并說出他們的優缺點。 QueryString 傳遞一個或多個安全性要求不高或是結構簡單的數值。但是對于傳遞數組或對象的話,就不能用這個方法了 session(viewstate) 簡單,但易丟失 作用于用戶個人,過量的存儲會導致服務器內存資源的耗盡。 application 對象的作用范圍是整個全局,也就是說對所有用戶都有效。其常用的方法用Lock和UnLock cookie 簡單,但可能不支持,可能被偽造 Cookie是存放在客戶端的,而session是存放在服務器端的。而且Cookie的使用要配合ASP.NET內置對象Request來使用 input ttype=hidden 簡單,可能被偽造 url參數簡單,顯示于地址欄,長度有限 Server.Transfer 把流程從當前頁面引導到另一個頁面中,新的頁面使用前一個頁面的應答流 數據庫穩定,安全,但性能相對弱 什么是Viewstate?它有什么作用?ViewState用來保存頁面狀態,就是說提交之后我們還可以看到文本框里面的內容就是ViewState保存的功勞。 ViewState只維護當前頁面的狀態,不同頁面之間不能共享,Session可以。 ViewState你可以理解為一個隱藏控件。ASP.Net頁面生命周期 每個頁面的生命周期為用戶的每一次訪問,也就是說每一次客戶端與服務器之間的一個往返過程.全局變量的生命周期在此之間.1. Page_Init(); 2. Load ViewState and Postback data; 3. Page_Load(); 4. Handle control events; 5. Page_PreRender(); 6. Page_Render(); 7. Unload event; 8. Dispose method called; ADO.net中常用的對象有哪些?分別描述一下。 答: Connection 打開數據庫連接 Command 執行數據庫命令 DataAdapter 連接數據,執行數據庫命令,填充DataSet DataSet 數據在內存中的緩存,數據結構 DataReader 只讀向前的讀取數據庫 DataReader和DataSet的異同 DataReader使用時始終占用SqlConnection,在線操作數據庫.任何對SqlConnection的操作都會引發DataReader的異常.因為DataReader每次只在內存中加載一條數據,所以占用的內存是很小的.因為DataReader的特殊性和高性能.所以DataReader是只進的.你讀了第一條后就不能再去讀取第一條了. DataSet則是將數據一次性加載在內存中.拋棄數據庫連接.讀取完畢即放棄數據庫連接.因為DataSet將數據全部加載在內存中.所以比較消耗內存.但是確比DataReader要靈活.可以動態的添加行,列,數據.對數據庫進行回傳更新操作. 存儲過程和sql語句的優缺點 優點: 1.提高性能,減少網絡傳輸,節約時間 。 2.減少網絡流量 存儲過程位于服務器上,調用的時候只須傳遞存儲過程的名稱以及參數,不用每次訪問都傳遞很長的sql 語句。 4.安全性 減少sql 注入式攻擊。 5.可維護性高 更新存儲過程通常比更改、測試以及重新部署程序集需要較少的時間和精力。 缺點: 1.交互性差 。 2.可移植性差 說出你所了解的數據庫訪問組件(例如ADO,至少4種) 答:ADO,ADO.Net,MDAC(Microsoft Data Access Components),Microsoft SQL Server OLE DB Provider, Microsoft Jet OLE DB Provider,Desktop Database Drivers ODBC Driver,Visual FoxPro ODBC Driver 什么是面向對象 萬物都是對象,其主要特征:封裝、繼承、多態 怎樣實現多態 1.通過對象直接調用成員函數時,始終默認使用該對象的類的成員函數(除非用:顯示指定類名)。2.通過指向對象的指針或引用調用成員函數時:如果該函數是實函數,則調用該指針或引用的類的成員函數;如果該函 數是虛函數,則調用該指針或引用指向的對象的類的成員函數。 面向對象的思想主要包括什么? 答:任何事物都可以理解為對象,其主要特征: 繼承。封裝。多態。特點:代碼好維護,安全,隱藏信息 什么是裝箱和拆箱? 答:從值類型接口轉換到引用類型裝箱。從引用類型轉換到值類型拆箱。裝箱(boxing)是將值類型的數據轉化成引用類型,int i=3; object o = i ;便是裝箱過程,而拆箱(unboxing)是將飲用類型數據轉換值類型,比如int j = (int)o;屬于拆箱 什么是Interface?它與Abstract Class有什么區別? 接口(Interface)是用來定義行為規范的,不會有具體實現,而抽象類除定義行為規范外,可以有部分實現,但一 個類能實現多個接口,但只能繼承一個父類 什么時候使用抽象類,什么時候用接口 接口用于規范,抽象類用于共性。接口中只能聲明方法,屬性,事件,索引器。而抽象類中可以有方法的實 現,也可以定義非靜態的類變量。抽象類是類,所以只能被單繼承,但是接口卻可以一次實現多個。抽象類可以 提供某些方法的部分實現,接口不可以.抽象類的實例是它的子類給出的。接口的實例是實現接口的類給出的。 再抽象類中加入一個方法,那么它的子類就同時有了這個方法。而在接口中加入新的方法,那么實現它的類就要 重新編寫(這就是為什么說接口是一個類的規范了)。接口成員被定義為公共的,但抽象類的成員也可以是私有 的、受保護的、內部的或受保護的內部成員(其中受保護的內部成員只能在應用程序的代碼或派生類中訪問)。 此外接口不能包含字段、構造函數、析構函數、靜態成員或常量。 什么是抽象類(abstract class)? 一種不可以被實例化的類。抽象類中一般含有抽象方法,當然也可有具體實現。繼承類只有實現過所有抽 象類的抽象方法后才能被實例化。 何時必須聲明一個類為抽象類? 當這個類中包含抽象方法時,或是該類并沒有完全實現父類的抽象方法時。 接口(interface)是什么? 只含有共有抽象方法(public abstract method)的類。這些方法必須在子類中被實現。 為什么不能指定接口中方法的修飾符? 接口中的方法用來定義對象之間通信的契約,指定接口中的方法為私有或保護沒有意義。他們默認為公有方法。 可以繼承多個接口么? 當然。 那么如果這些接口中有重復的方法名稱呢? 這種情況中你可以決定如何實現。當然需要特別得小心。但是在編譯環節是沒有問題的。 接口和抽象類的區別是什么? 接口中所有方法必須是抽象的,并且不能指定方法的訪問修飾符。抽象類中可以有方法的實現,也可以指 定方法的訪問修飾符。詳述.NET里class和struct的異同! 類是引用類型,可以繼承類、接口和被繼承,有默認的構造函數,有析構函數,可以使用abstract和sealed,有protected修飾符,必須使用new初始化。結構是值類型,只能繼承接口,不能被繼承,沒有默認的構造函數,可以創建,沒有析構函數,不可以用abstract和sealed,沒有protected修飾符,可以不用new初始化。如何選擇結構還是類 1 堆棧的空間有限,對于大量的邏輯的對象,創建類要比創建結構好一些 2 結構表示如點、矩形和顏色這樣的輕量對象 例如,如果聲明一個含有 1000 個點對象的數組,則將為引用每個對象分配附加的內存。 在此情況下,結構的成本較低。 3 在表現抽象和多級別的對象層次時,類是最好的選擇 4 大多數情況下該類型只是一些數據時,結構時最佳的選擇 C#中的接口和類有什么異同。 異: 不能直接實例化接口。 接口不包含方法的實現。 接口、類和結構可從多個接口繼承。但是C# 只支持單繼承:類只能從一個基類繼承實現。 類定義可在不同的源文件之間進行拆分。 同: 接口、類和結構可從多個接口繼承。 接口類似于抽象基類:繼承接口的任何非抽象類型都必須實現接口的所有成員。 接口可以包含事件、索引器、方法和屬性。 一個類可以實現多個接口。 const和readonly有什么區別? const關鍵字用來聲明編譯時常量,readonly用來聲明運行時常量。 用sealed修飾的類有什么特點 sealed 修飾符用于防止從所修飾的類派生出其它類。如果一個密封類被指定為其他類的基類,則會發生編譯時錯誤。 密封類不能同時為抽象類。 sealed 修飾符主要用于防止非有意的派生,但是它還能促使某些運行時優化。具體說來,由于密封類永 遠不會有任何派生類,所以對密封類的實例的虛擬函數成員的調用可以轉換為非虛擬調用來處理。 虛函數的用法 答: 1)virtual指明一成員函數為虛函數,而virtual僅用于類的定義里,在類外可不加此關鍵字. 2)一個類的成員函數被定義為虛函數時,子類該函數仍保持虛函數特征. 3)子類覆蓋此函數時,定義里可不加virtual關鍵字,但函數聲明要和基類的完全一致!且此聲明是必須的. 4)不是純虛函數時,父類的虛函數必須要實現; 而若將父類的虛函數設定為純虛函數時,子類必需要覆蓋之而且必須要實現之! 解釋virtual、sealed、override和abstract的區別 virtual申明虛方法的關鍵字,說明該方法可以被重寫 sealed說明該類不可被繼承 override重寫基類的方法 abstract申明抽象類和抽象方法的關鍵字,抽象方法不提供實現,由子類實現,抽象類不可實例化。 重載和覆寫有什么區別? 答:重載是方法的名稱相同,不同的參數類型,不同的參數個數,不同的參數順序。覆寫提供了子類中改變父類方法行為的實現(是進行基類中函數的重寫)。 在方法定義中,virtual有什么含義? 答:被virtual修飾的方法可以被子類覆寫 能夠將非靜態的方法覆寫成靜態方法嗎? 答:不能,覆寫方法的簽名必須與被覆寫方法的簽名保持一致,除了將virtual改為override。 可以覆寫私有的虛方法嗎? 答:不可以,甚至子類中無法訪問父類中的私有方法 能夠阻止某一個類被其他類繼承嗎? 答:可以,使用關鍵字sealed 能夠實現允許某個類別繼承,但不允許其中的某個方法被覆寫嗎? 答:可以,標記這個類為public,并標記這個方法為sealed。 如何區別重載方法? 不同的參數類型,不同的參數個數,不同的參數順序 c#繼承:base 表示當前對象基類的實例(使用base關鍵字可以調用基類的成員)this表示當前類的實例在靜態方法中不可以使用base和this關鍵字派生類會繼承基類所有的成員但是構造函數和析構函數不會被繼承注意如果派生類的方法和基類的方法同名則基類中的方法將會被隱藏如果需要隱藏則可以使用關鍵字new來隱藏如果不寫new關鍵字默認處理為隱藏雖然基類中同名的方法被隱藏了但是還是可以通過base關鍵字來調用/如果子類方法的方法名和基類的方法名相同時,系統將隱藏基類同名方法,自動調用子類的同名方法/派生類會繼承基類所有的成員,但是不能顯示調用基類的是有成員/在派生類中不可以調用基類的是有成員,如num1,num2,但是可以實現調用基類方法virtual 用在基類中指定一個虛方法屬性表示這個方法屬性可以重寫override 用在派生類中表示對基類虛方法屬性的重寫不能重寫非虛方法或靜態方法重寫的基方法必須是 virtualabstract 或 override 的為什么 override 也可以重寫呢因為基類中的 override 實際上是對基類的基類進行的重寫由于繼承可傳遞所以也可以對基類中 override 的方法進行重寫override 聲明不能更改 virtual 方法的可訪問性override 方法和 virtual 方法必須具有相同的訪問級別修飾符不能使用修飾符 newstaticvirtual 或 abstract 來修改 override 方法重寫屬性聲明必須指定與繼承屬性完全相同的訪問修飾符類型和名稱并且被重寫的屬性必須是 virtualabstract 或 override 的標記允許被重寫修飾靜態方法中不允許使用virtual關鍵字成員變量允許使用virtual關鍵字屬性可以被聲明為虛屬性(使用virtual關鍵字)重寫基類的方法(重寫同名的方法中有virtual關鍵字的方法)重寫和隱藏的區別隱藏(new關鍵字)是給子類的同名方法分配新的內存空間重寫(override關鍵字)是子類的同名方法放在基類同名方法的原來所在位置基類的同名方法位置向后移屬性也可以重寫virtual關鍵字和override關鍵字是成對出現的否則是語法錯誤派生類可以通過將重寫聲明為 sealed 來停止虛擬繼承這需要在類成員聲明中的 override 關鍵字前面放置 sealed 關鍵字在子類中重寫基類中的虛方法時可以使用base關鍵字調用基類中的虛方法/使用base關鍵可以在子類中訪問基類同名的方法/父類的引用指向子類的實例Test ts = new Test2();父類的引用指向子類的實例(調用的是子類的方法)父類的引用只認識父類的方法不認識子類的新方法可以用來調用被子類覆蓋的父類的方法父類的引用依然到父類方法位置去調用如果基類方法被聲明為virtual并且在子類中被override結果訪問到的是被子類override的方法C#中的委托是什么?事件是不是一種委托? 委托可以把一個方法作為參數代入另一個方法。委托可以理解為指向一個函數的引用。是,是一種特殊的委托 C#中的堆和棧 棧(Stack)由系統管理生存期,存儲代碼執行和調用路徑,執行或調用完畢即從棧中清除; 堆(Heap)中保存值和對象,調用完畢之后依然存在,由垃圾回收器查找棧中有無指向該值或對象的引用,無則從堆中刪除你對泛型了解嗎?簡單說明一下泛型的有什么好處?泛型:通過參數化類型來實現在同一份代碼上操作多種數據類型。利用“參數化類型”將類型抽象化,從而實現靈活的復用 好處是類型安全和減少裝箱、拆箱。提高性能、類型安全和質量,減少重復性的編程任務 C#中所有對象共同的基類是什么? System.Object. 如何在C#中實現繼承? 在類名后加上一個冒號,再加上基類的名稱。 C#支持多重繼承嗎? 不支持。可以用接口來實現。 被protected修飾的屬性/方法在何處可以訪問? 在繼承或間接繼承與這個類的子類中可以訪問。 私有成員會被繼承么? 會,但是不能被訪問。所以看上去他們似乎是不能被繼承的,但實際上確實被繼承了。 C#提供一個默認的無參構造函數,當我實現了另外一個有一個參數的構造函數時,還想保留這個無參數的構 造函數。這樣我應該寫幾個構造函數? 答:兩個,一旦你實現了一個構造函數,C#就不會再提供默認的構造函數了,所以需要手動實現那個無參構造 函數。 簡述 private、 protected、 public、 internal 修飾符的訪問權限。 private : 私有成員, 在類的內部才可以訪問。 protected : 保護成員,該類內部和繼承類中可以訪問。 public : 公共成員,完全公開,沒有訪問限制。 internal: 在同一命名空間內可以訪問。 new的兩種用法 答:實例話對象,隱藏基類方法。.new有幾種用法 第一種:new Class(); 第二種:覆蓋方法 public new XXXX() 第三種:new 約束指定泛型類聲明中的任何類型參數都必須有公共的無參數構造函數。 3.datagrid.datasouse可以連接什么數據源 dataset,datatable,dataview dataset,datatable,dataview , IList 類成員有( )種可訪問形式 可訪問性:public ,protected ,private,internal 委托與事件的用法 答:public delegate void handels();/返回值是void,沒有參數 public event handels eventHandels; his.eventHandels = new handels(fun); public void fun() 傳入某個屬性的SET方法的隱含參數的名稱是什么? 答:value,它的類型和屬性所聲明的類型相同。 string是值類型還是引用類型? 引用類型 String類與StringBuilder類有什么區別?為什么在.Net類庫中要同時存在這2個類?(簡答) stringBuilder比string更節約內存,所以stringBuilder更快 String 對象是不可改變的。每次使用 System.String 類中的方法之一或進行運算時(如賦值、拼接等)時,都要 在內存中創建一個新的字符串對象,這就需要為該新對象分配新的空間。而 StringBuilder 則不會。在需要對字 符串執行重復修改的情況下,與創建新的 String 對象相關的系統開銷可能會非常昂貴。如果要修改字符串而不 創建新的對象,則可以使用 System.Text.StringBuilder 類。例如,當在一個循環中將許多字符串連接在一起時 ,使用 StringBuilder 類可以提升性能。 在C中,string str = null 與 string str = “” 請盡量使用文字或圖象說明其中的區別。 答:string str = null 是不給他分配內存空間,而string str = 給它分配長度為空字符串的內存空間。 ASP.net的身份驗證方式有哪些?分別是什么原理? 答:Windwos(默認) 用IIS.From(窗體) 用帳戶.Passport(密鑰) Session有什么重大BUG,微軟提出了什么方法加以解決? 答:是iis中由于有進程回收機制,系統繁忙的話Session會丟失,可以用Sate server或SQL Server數據庫的方式存儲Session不過這種方式比較慢,而且無法捕獲Session的END事件 c#中的三元運算符是 ?: .能用foreach遍歷訪問的對象需要實現() 接口或聲明 ( GetEnumerator)方法的類型。 . 和 有什么區別? 表示綁定的數據源 是服務器端代碼塊 常量 在.net(C# or )中如何獲得當前窗體或控件的句柄,特別是控件本身的句柄(請列舉)this(C#) Me(). .C#可否對內存進行直接的操作? 在.net下,.net引用了垃圾回收(GC)功能,它替代了程序員 不過在C#中,不能直接實現Finalize方法,而是在析構函數中調用基類的Finalize()方法 DateTime是否可以為null? 不能,因為其為Struct類型,而結構屬于值類型,值類型不能為null,只有引用類型才能被賦值null DateTime.Parse(myString); 這行代碼有什么問題? 有問題,當myString不能滿足時間格式要求的時候,會引發異常,建議使用DateTime.TryParse() net的錯誤處理機制是:采用try-catch-finally結構, 為什么不提倡catch(Exception) try.catch在出現異常的時候影響性能; 應該捕獲更具體得異常,比如IOExeception,OutOfMemoryException等 catch(Exception e)throw e;和catch(Exception e)throw;的區別 將發生的異常對象拋出,另一個只是拋出異常,并沒有拋出原異常對象) error和exception區別: error 表示恢復不是不可能但很困難的情況下的一種嚴重問題。比如說內存溢出。不可能指望程序能處理這樣的情況。 exception 表示一種設計或實現問題。也就是說,它表示如果程序運行正常,從不會發生的情況。GET與POST的區別 在FORM提交的時候,如果不指定Method,則默認為GET請求,Form中提交的數據將會附加在url之后,以?分開與url分開。字母數字字符原樣發送,但空格轉換為“+“號,其它符號轉換為%XX,其中XX為該符號以16進制表示的ASCII(或ISO Latin-1)值。GET請求請提交的數據放置在HTTP請求協議頭中,而POST提交的數據則放在實體數據中; 在使用 POST 方法的情況下,傳輸數據時不會將數據作為 URL 的一部分;它們會作為一個獨立的實體來傳輸。因此,POST 方法更安全,你也可以用這個方法傳輸更多的數據。而且用 POST 傳輸的數據不一定要是文本,用 GET 方法傳輸的卻一定要是文本。 (1)get是從服務器上獲取數據,post是向服務器傳送數據。 (1)在客戶端,Get方式在通過URL提交數據,數據在URL中可以看到;POST方式,數據放置在HTML HEADER內提交。 (2)對于get方式,服務器端用Request.QueryString獲取變量的值,對于post方式,服務器端用Request.Form獲取提交的數據。 (2)GET方式提交的數據最多只能有1024字節,而POST則沒有此限制。 (3)安全性問題。正如在(1)中提到,使用 Get 的時候,參數會顯示在地址欄上,而 Post 不會。所以,如果這些數據是中文數據而且是非敏感數據,那么使用 get;如果用戶輸入的數據不是中文字符而且包含敏感數據,那么還是使用 post為好。 Bind和Eval函數的區別 綁定表達式 1 Eval 單向綁定:數據是只讀的 Bind 雙向綁定:數據可以更改,并返回服務器端,服務器可以處理更改后的數據,如存入數據庫. 2.當對次表達式操作時候,必須用Eval 如 3 綁定控件的屬性時要用Bind,而Eval則是其它一些。 例如:asp:TextBox ID=First RunAt=Server Text= / 例如: Response.Redirect和Server.Transfer 請求的過程: 1)瀏覽器aspx文件請求-服務器執行-遇到Response.Redirect語句-服務器發送Response.Redirect后面的地址給客戶機端的瀏覽器-瀏覽器請求執行新的地址 2)瀏覽器aspx文件請求-服務器執行-遇到Server.Transfer語句-服務器轉向新的文件 可以見Server.Transfer比Response.Redirect少了一次服務器發送回來和客戶端再請求的過程. 跳轉對象: 1)Response.Redirect可以切換到任何存在的網頁。 2)Server.Transfer只能切換到同目錄或者子目錄的網頁. 數據保密: 1、Response.Redirect后地址會變成跳轉后的頁面地址。 2、Server.Transfer后地址不變,隱藏了新網頁的地址及附帶在地址后邊的參數值。具有數據保密功能。 傳遞的數據量(網址后附帶的參數): 1、Response.Redirect能夠傳遞的數據以2KB(也就是地址欄中地址的最大的長度)為限。 2、傳遞的數據超過2KB時,務必使用Server.Transfer。Server.UrlEncode、HttpUtility.UrlDecode的區別 Server.UrlEncode的編碼方式是按照本地程序設置的編碼方式進行編碼的,而HttpUtility.UrlEncode是默認的按照.net的utf-8格式進行編碼的。Static 和 非Static的區別: 一、用Static聲明的方法和變量,不需要實例化該類就調用; 二、Static的,就一定要用實例化的對象來調用,即用new來實例化。 舉例說: 如果有一個類People,有一個Static的方法MiaoShu(), 調用方法就是 People.MisoShu() 有一個非Static的方法getName(), 調用方法就是 People p= new People(); p.getName(); 如何實現連接池 確保你每一次的連接使用相同的連接字符串(和連接池相同);只有連接字符串相同時連接池才會工作。如果連接字符串不相同,應用程序就不會使用連接池而是創建一個新的連接。 優點 使用連接池的最主要的優點是性能。創建一個新的數據庫連接所耗費的時間主要取決于網絡的速度以及應用程序和數據庫服務器的(網絡)距離,而且這個過程通常是一個很耗時的過程。而采用數據庫連接池后,數據庫連接請求可以直接通過連接池滿足而不需要為該請求重新連接、認證到數據庫服務器,這樣就節省了時間。 缺點 數據庫連接池中可能存在著多個沒有被使用的連接一直連接著數據庫(這意味著資源的浪費)。 技巧和提示 1 當你需要數據庫連接時才去創建連接池,而不是提前建立。一旦你使用完連接立即關閉它,不要等到垃圾收集器來處理它。 2 在關閉數據庫連接前確保關閉了所有用戶定義的事務。 3 不要關閉數據庫中所有的連接,至少保證連接池中有一個連接可用。如果內存和其他資源是你必須首先考慮的問題,可以關閉所有的連接,然后在下一個請求到來時創建連接池。 連接池FAQ 1 何時創建連接池? 當第一個連接請求到來時創建連接池;連接池的建立由數據庫連接的連接字符創來決定。每一個連接池都與一個不同的連接字符串相關。當一個新的連接請求到來時如果連接字符串和連接池使用的字符串相同,就從連接池取出一個連接;如果不相同,就新建一個連接池。 2 何時關閉連接池? 當連接池中的所有連接都已經關閉時關閉連接池。 3 當連接池中的連接都已經用完,而有新的連接請求到來時會發生什么? 當連接池已經達到它的最大連接數目時,有新的連接請求到來時,新的連接請求將放置到連接隊列中。當有連接釋放給連接池時,連接池將新釋放的連接分配給在隊列中排隊的連接請求。你可以調用close和dispose將連接歸還給連接池。 4 我應該如何允許連接池? 對于.NET應用程序而言,默認為允許連接池。(這意味著你可以不必為這件事情做任何的事情)當然,如果你可以在SQLConnection對象的連接字符串中加進Pooling=true;確保你的應用程序允許連接池的使用。 5 我應該如何禁止連接池? ADO.NET默認為允許數據庫連接池,如果你希望禁止連接池,可以使用如下的方式: 1) 使用SQLConnection對象時,往連接字符串加入如下內容:Pooling=False; 2) 使用OLEDBConnection對象時,往連接字符串加入如下內容:OLE DB Services=-4; 提高.NET的性能 1 使用異步方式調用Web服務和遠程對象 只要有可能就要避免在請求的處理過程中對Web服務和遠程對象的同步調用,因為它占用的是的ASP.NET 線程池中的工作線程,這將直接影響Web服務器響應其它請求的能力。 2 使用適當的Caching策略來提高性能 3 判斷字符串,不要用比較。 /避免 if(strABC!=null & strABC!=) /推薦 if(!strABC.IsNullOrEmpty) 4 頁面優化 5 用完馬上關閉數據庫連接 6 盡量使用存儲過程,并優化查詢語句 7 只讀數據訪問用SqlDataReader,不要使用DataSet.UDP連接和TCP連接的異同 答:前者只管傳,不管數據到不到,無須建立連接.后者保證傳輸的數據準確,須要連結. 請解釋轉發與跳轉的區別 轉發就是服務端的跳轉A頁面提交數據到B頁面,B頁面進行處理然后從服務端跳轉到其它頁面 跳轉就是指客戶端的跳轉簡述你對XML Web Service的原理的認識? 答:利用SOAP(簡單對象訪問協議)在http上執行遠程方法的調用,也可以使用WSDL(Web服務描述語言)來 完成完整的描述Web服務,然后用UDDI注冊各個服務提供商提供的服務,以便共享他們。 什么叫應用程序域? 答:應用程序域可以理解為一種輕量級進程。起到安全的作用。占用資源小。 CTS、CLS、CLR分別作何解釋? 答:CTS:通用語言系統。CLS:通用語言規范。CLR:公共語言運行庫。 什么是受管制的代碼? 答:unsafe:非托管代碼。不經過CLR運行。 什么是強類型系統? 答:RTTI:類型識別系統。 什么是code-behind技術 codebehind是指代碼和用戶界面分開 aspx and cs 在.net中,配件的意思是? 答:程序集。(中間語言,源數據,資源,裝配清單) 常用的調用WebService的方法有哪些? 答:1.使用WSDL.exe命令行工具。 2.使用VS.NET中的Add Web Reference菜單選項 net Remoting 的工作原理是什么? 答:服務器端向客戶端發送一個進程編號,一個程序域編號,以確定對象的位置。 O/R Mapping 的原理 答:利用反射,配置將對象和數據庫表映射 remoting和webservice兩項技術的理解以及實際中的應用。 答:WS主要是可利用HTTP,穿透防火墻。而Remoting可以利用TCP/IP,二進制傳送提高效率。 out保留字怎么使用,什么時候使用 答:有時為了從一個函數中返回多個值,我們需要使用out關鍵字,把輸出值賦給通過引用傳遞給方法的變量(也就是參數)。但C#要求變量再被引用的前必須初始化。在調用該方法時,還需要添加out關鍵字 PDB是什么東西? 在調試中它應該放在哪里? PDB是用于保存調試和項目狀態信息的文件,在debug的時候將產生pdb文件,調試的時候應該放在和對應應用 程序集相同目錄。 使用ASMX的XML Web服務與使用SOAP的.NET Remoting的區別? Web服務使用的消息機制,而Remoting采用的RPC. Web Service能用于不同平臺,不同語言,Remoting只適用 于.Net。效率上Remoting高于Xml Web Service 類型系統是由XMLSchema表示的嗎?CLS是XMLSchema表示的嗎? 不清楚 從概念上闡述前期綁定(early-binding)和后期綁定(late-binding)的區別? 這個就像是強弱類型的比較相似,前期綁定是在編譯的時候就確定了要綁定的數據,而后期綁定是在運行的時候 才填充數據。所以前期綁定如果失敗,會在編譯時報編譯錯誤,而后期綁定失敗只有在運行時的時候才發生 調用Assembly.Load算靜態引用還是動態引用? 動態 列舉一下你所了解的XML技術及其應用 答:保存配置,站與站之間的交流,WEB SERVICE。以及與數據庫的數據交互等地方都要用它. 7.如何理解委托? 答: 相當于函數指針,定義了委托就可以在不調用原方法名稱的情況下調用那個方法. 委托具有以下特點: 委托類似于 C+ 函數指針,但它是類型安全的。 委托允許將方法作為參數進行傳遞。 委托可用于定義回調方法。 委托可以鏈接在一起;例如,可以對一個事件調用多個方法。 方法不需要與委托簽名精確匹配。有關更多信息,請參見協變和逆變。 C# 2.0 版引入了匿名方法的概念,此類方法允許將代碼塊作為參數傳遞,以代替單獨定義的方法。 概述反射和序列化 反射:程序集包含模塊,而模塊包含類型,類型又包含成員。反射則提供了封裝程序集、模塊和類型的對 象。您可以使用反射動態地創建類型的實例,將類型綁定到現有對象,或從現有對象中獲取類型。然后, 可以調用類型的方法或訪問其字段和屬性 序列化:序列化是將對象轉換為容易傳輸的格式的過程。例如,可以序列化一個對象,然后使用 HTTP 通 過 Internet 在客戶端和服務器之間傳輸該對象。在另一端,反序列化將從該流重新構造對象。 11) XmlSerializer是如何工作的?使用這個類的進程需要什么ACL權限? 我只知道XmlSerializer是將對象的屬性和字段進行序列化和反序列化的,序列化成為xml數據,反序列化再將xml 轉換成對象。應該至少需要ACL權限中的讀權限. 23)XmlSerializer使用的針對屬性的模式有什么好處?解決了什么問題? 只序列化有用的數據,而不是序列化整個對象。實現沒必要的數據冗余,和提升序列化時的性能。26.根據委托(delegate)的知識,請完成以下用戶控件中代碼片段的填寫: namespace test public delegate void OnDBOperate(); public class UserControlBase : System.Windows.Forms.UserControl public event OnDBOperate OnNew; privatevoidtoolBar_ButtonClick(objectsender,System.Windows.Forms.ToolBarButtonClickEventArgs e) if(e.Button.Equals(BtnNew) /請在以下補齊代碼用來調用OnDBOperate委托簽名的OnNew事件。 答:if( OnNew != null ) OnNew( this, e ); 27.分析以下代碼,完成填空 string strTmp = abcdefg某某某; int i= System.Text.Encoding.Default.GetBytes(strTmp).Length; int j= strTmp.Length; 以上代碼執行完后,i= j= 答:i=13,j=10 28.SQLSERVER服務器中,給定表 table1 中有兩個字段 ID、LastUpdateDate,ID表示更新的事務號, LastUpdateDate表示更新時的服務器時間,請使用一句SQL語句獲得最后更新的事務號 答:Select ID FROM table1 Where LastUpdateDate = (Select MAX(LastUpdateDate) FROM table1) 29.根據線程安全的相關知識,分析以下代碼,當調用test方法時i10時是否會引起死鎖?并簡要說明理由。 public void test(int i) lock(this) if (i10) i-; test(i); 答:不會發生死鎖,(但有一點int是按值傳遞的,所以每次改變的都只是一個副本,因此不會出現死鎖。但如果 把int換做一個object,那么死鎖會發生) 3) 什么叫圈復雜度(cyclomatic complexity)?為什么它很重要? 不知道,望指教 ? 4) 寫一個標準的lock(),在訪問變量的前后創建臨界區,要有雙重檢查,lock的使用 public void LockTest() Object lockObj = new Object(); lock (lockObj) / 5) 什么叫FullTrust?放入GAC的assembly是否是FullTrust的? FullTrust完全信任。放入GAC中的Assembly是否FullTrust我的理解不是。我理解FullTrust是可以通過代碼設定的 6) 代碼加上需要安全權限的特性有什么好處? 可以更加靈活的設置對代碼的訪問權限,實現代碼級保護。?這點不是特清楚,有明白的給講解下 7) gacutil /l | find /i Corillian 這句命令的作用是什么? 全局程序集緩存中如果有Corillian就更新該程序集,沒有就安裝 8) sn -t foo.dll 這句命令是干嘛的? 顯示程序集foo.dll的公鑰標記 9) DCOM需要防火墻打開哪些端口?端口135是干嘛用的? 135端口,因為DCOM的端口號是隨機分配的,默認情況下,會分配1024以上的端口號,所以默認情況下,DCOM 不能穿越防火墻。因為根本不曉得開哪個端口。但有解決辦法可以使DCOM分配的端口號固定,135是遠程過程 調用(RPC)的默認端口 10)對比OOP和SOA,它們的目的分別是什么? 我想OOP和SOA應該沒有

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論