注:標明*的問題屬於選擇性掌握的內容,能掌握更好,沒掌握也不要緊。html
下面的參考解答只是幫助你們理解,不用背,變幻無窮,不要夢想着把題覆蓋了,下面的題是供你們查漏補缺用的,真正的把這些題搞懂了,才能「以不變應萬變」。回答問題的時候能聯繫作過項目的例子是最好的,有的問題後面我已經補充聯繫到項目中的對應的案例了。程序員
1、簡述 private、 protected、 public、 internal 修飾符的訪問權限。web
private : 私有成員, 在類的內部才能夠訪問。面試
protected : 保護成員,該類內部和繼承類中能夠訪問。ajax
public : 公共成員,徹底公開,沒有訪問限制。算法
internal: 當前程序集內能夠訪問。sql
2、ADO.NET中的五個主要對象數據庫
SQLConnection:主要是開啓程序和數據庫之間的鏈接。Close和Dispose的區別,Close之後還能夠Open,Dispose之後則不能再用編程
SQLCommand:主要能夠用來對數據庫發出一些指令,例如查詢、新增、修改、刪除指令json
DataAdapter:主要是在數據源以及DataSet 之間執行數據傳輸的工做。
DataSet:這個對象能夠視爲一個暫存區(Cache),能夠把從數據庫中所查詢到的數據保留起來,DataSet是放在內存中的。
DataSet包含若干DataTable、DataTableTable包含若干DataRow。
DataReader:當咱們只須要循序的讀取數據而不須要其它操做時,可使用DataReader 對象。DataReader對象只是一次一筆向下循序的讀取數據源中的數據,這些數據是存在數據庫服務器中的,而不是一次性加載到程序的內存中的,只能(經過遊標)讀取當前行的數據。
ADO.NET 使用Connection 對象來鏈接數據庫,使用Command 或DataAdapter對象來執行SQL語句,並將執行的結果返回給DataReader 或 DataAdapter ,而後再使用取得的DataReader 或DataAdapter 對象操做數據結果。
3、列舉ASP.NET 頁面之間傳遞值的幾種方式。
1.使用QueryString, 如....?id=1; response. Redirect()....
2.使用Session變量
3.使用Server.Transfer
4.Cookie傳值
4、C#中的委託是什麼?事件是否是一種委託?事件和委託的關係。
委託能夠把一個方法做爲參數代入另外一個方法。
委託能夠理解爲指向一個函數的指針。
委託和事件沒有可比性,由於委託是類型,事件是對象,下面說的是委託的對象(用委託方式實現的事件)和(標準的event方式實現)事件的區別。事件的內部是用委託實現的。由於對於事件來說,外部只能「註冊本身+=、註銷本身-=」,外界不能夠註銷其餘的註冊者,外界不能夠主動觸發事件,所以若是用Delegate就無法進行上面的控制,所以誕生了事件這種語法。事件是用來閹割委託實例的,類比用一個自定義類閹割List。事件只能add、remove本身,不能賦值。事件只能+=、-=,不能= 。加分的補充回答:事件內部就是一個private的委託和add、remove兩個方法
面試聊:用Reflector查看.Net的類的內部實現,解決問題。
5、override與重載(overload)的區別
重載是方法的名稱相同。參數或參數類型不一樣,進行屢次重載以適應不一樣的須要。重載(overload)是面向過程的概念。
Override 是進行基類中函數的重寫。Override是面向對象的概念
6、C#中索引器是否只能根據數字進行索引?是否容許多個索引器參數?
參數的個數和類型都是任意的。加分的補充回答:用reflector反編譯能夠看出,索引器的內部本質上就是set_item、get_item方法。
7、屬性和public字段的區別是什麼?調用set方法爲一個屬性設值,而後用get方法讀取出來的值必定是set進去的值嗎?
屬性能夠對設值、取值的過程進行非法值控制,好比年齡禁止設值負數,屬性內部本質上就是set_***、get_***方法,
必須手寫掌握的代碼(既包含拿電腦寫,拿筆寫):
一、 手寫三層架構
二、 手寫冒泡排序
三、 手寫AJAX:XMLHttpRequest
四、 手寫增刪改查、SQLHelper
冒泡排序
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace maopao1 { class Program { static void Main(string[] args) { int[] mao = { 2, 8, 4, 6, 9 }; for (int i = 0; i < mao.Length-1; i++) { for (int j = 0; j < mao.Length-1-i; j++) { if (mao[j]>mao[j+1]) { int temp = mao[j]; mao[j] = mao[j + 1]; mao[j + 1] = temp; } } } for (int i = 0; i < mao.Length; i++) { Console.Write(mao[i]); } Console.ReadKey(); } } }
8、三層架構
一般意義上的三層架構就是將整個業務應用劃分爲:表現層(UI)、業務邏輯層(BLL)、數據訪問層(DAL)。
區分層次的目的即爲了「高內聚,低耦合」的思想。
表現層(UI):通俗講就是展示給用戶的界面,即用戶在使用一個系統的時候的所見所得。
業務邏輯層(BLL):針對具體問題的操做,也能夠說是對數據層的操做,對數據業務邏輯處理。
數據訪問層(DAL):該層所作事務直接操做數據庫,針對數據的增添、刪除、修改、更新、查找等每層之間是一種垂直的關係。
三層結構是N層結構的一種,通常來講,層次之間是向下依賴的,下層代碼未肯定其接口(契約)前,上層代碼是沒法開發的,下層代碼接口(契約)的變化將使上層的代碼一塊兒變化。
優勢: 分工明確,條理清晰,易於調試,並且具備可擴展性。
缺點: 增長成本。
9、關於拆箱裝箱:
1)什麼是裝箱(boxing)和拆箱(unboxing)? (*)
裝箱:從值類型接口轉換到引用類型。
拆箱:從引用類型轉換到值類型。
2)下面三句代碼有沒有錯,以inboxing或者unboxing爲例,解釋一下內存是怎麼變化的
int i=10;
object obj = i; //boxing
int j = (int)obj;//unboxing
10、在dotnet中類(class)與結構(struct)的異同?
Class能夠被實例化,屬於引用類型,是分配在內存的堆上的。類是引用傳遞的。
Struct屬於值類型,是分配在內存的棧上的。結構體是複製傳遞的。加分的回答:Int32、Boolean等都屬於結構體。
11、堆和棧的區別?
棧是編譯期間就分配好的內存空間,所以你的代碼中必須就棧的大小有明確的定義;局部值類型變量、值類型參數等都在棧內存中。
堆是程序運行期間動態分配的內存空間,你能夠根據程序的運行狀況肯定要分配的堆內存的大小。
12、能用foreach遍歷訪問的對象的要求
須要實現IEnumerable接口或聲明GetEnumerator方法的類型。
13、GC是什麼? 爲何要有GC?
C/C++中由程序員進行對象的回收像學校食堂中由學生收盤子,.Net中由GC進行垃圾回收像餐館中店員去回收。
GC是垃圾收集器(Garbage Collection)。程序員不用擔憂內存管理,由於垃圾收集器會自動進行管理。GC只能處理託管內存資源的釋放,對於非託管資源則不能使用GC進行回收,必須由程序員手工回收,一個例子就是FileStream或者SqlConnection須要程序員調用Dispose進行資源的回收。
要請求垃圾收集,能夠調用下面的方法:GC.Collect()通常不須要手動調用GC.Collect()。當一個對象沒有任何變量指向(再也不能使用)的時候就能夠被回收了。
基礎知識:當沒有任何變量指向一個對象的時候對象就能夠被回收掉了,但不必定會當即被回收。
1四、值類型和引用類型的區別?
C#的值類型包括:結構體(數值類型,bool型,用戶定義的結構體),枚舉,可空類型。
C#的引用類型包括:數組,用戶定義的類、接口、委託,object,字符串。
數組的元素,無論是引用類型仍是值類型,都存儲在託管堆上。
1.將一個值類型變量賦給另外一個值類型變量時,將複製包含的值。引用類型變量的賦值只複製對對象的引用,而不復制對象自己。
2.值類型不可能派生出新的類型:全部的值類型均隱式派生自 System.ValueType。但與引用類型相同的是,結構也能夠實現接口。
3.值類型不可能包含 null 值:然而,可空類型功能容許將 null 賦給值類型。
4.每種值類型均有一個隱式的默認構造函數來初始化該類型的默認值。
15、C#中的接口和類有什麼異同。
不一樣點:
不能直接實例化接口。
接口不包含方法的實現。
接口能夠多繼承,類只能單繼承。
類定義可在不一樣的源文件之間進行拆分。
相同點:
接口、類和結構均可以從多個接口繼承。
接口相似於抽象基類:繼承接口的任何非抽象類型都必須實現接口的全部成員。
接口和類均可以包含事件、索引器、方法和屬性。
基礎知識:接口只能定義方法(只能定義行爲,不能定義實現也就是字段),由於事件、索引器、屬性本質上都是方法,因此接口中也能夠定義事件、索引器、屬性。
1六、abstract class和interface有什麼區別?
相同點:
都不能被直接實例化,均可以經過繼承實現其抽象方法。
不一樣點:
接口支持多繼承;抽象類不能實現多繼承。
接口只能定義行爲;抽象類既能夠定義行爲,還可能提供實現。
接口只包含方法(Method)、屬性(Property)、索引器(Index)、事件(Event)的簽名,但不能定義字段和包含實現的方法;
抽象類能夠定義字段、屬性、包含有實現的方法。
接口能夠做用於值類型(Struct)和引用類型(Class);抽象類只能做用於引用類型。例如,Struct就能夠繼承接口,而不能繼承類。
加分的補充回答:講設計模式的時候SettingsProvider的例子。
1七、是否能夠繼承String類?
String類是sealed類故不能夠繼承。
sealed是不容許被繼承的,單列的時候能夠這樣約束
1八、
static void Main(string[] args) { Console.WriteLine(GetIt()); Console.ReadKey(); } static int GetIt() { int i = 8; try { i++; Console.WriteLine("a"); return i;//把返回值設定爲i,而後「儘快」返回(沒啥事就回去吧) } finally { Console.WriteLine("b"); i++; } }
上面程序的執行結果是ab9
1九、int、DateTime、string是否能夠爲null?
int、DateTime不能,由於其爲Struct類型,而結構屬於值類型,值類型不能爲null,只有引用類型才能被賦值null。string能夠爲null。
C#中int等值類型不能夠爲null、而數據庫中的int能夠爲null,這就是糾結的地方。int?就變成了可空的int類型。bool?、DateTime?
int?翻譯生成.Net的Nullable<int>,CTS。
29、using關鍵字有什麼用?什麼是IDisposable?
using能夠聲明namespace的引入,還能夠實現非託管資源的釋放,實現了IDisposiable的類在using中建立,using結束後會自動調用該對象的Dispose方法,釋放資源。加分的補充回答:using其實等價於try……finally,用起來更方便。
30、XML 與 HTML 的主要區別
1. XML是區分大小寫字母的,HTML不區分。
2. 在HTML中,若是上下文清楚地顯示出段落或者列表鍵在何處結尾,那麼你能夠省略</p>或者</li>之類的結束標記。在XML中,絕對不能省略掉結束標記。
HTML:<img src="1.jpg"><br><br>
XML:<img src="1.jpg"></img><br/><br/>
3. 在XML中,擁有單個標記而沒有匹配的結束標記的元素必須用一個 / 字符做爲結尾。這樣分析器就知道不用 查找結束標記了。
4. 在XML中,屬性值必須分裝在引號中。在HTML中,引號是可用可不用的。
5. 在HTML中,能夠擁有不帶值的屬性名。在XML中,全部的屬性都必須帶有相應的值。
XML是用來存儲和傳輸數據的
HTML是用來顯示數據的
若是使用了徹底符合XML語法要求的HTML,那麼就叫作符合XHTML標準。符合XHTML標準的頁面有利於SEO。
31、string str = null 與 string str =」」說明其中的區別。
答:string str = null 是不給他分配內存空間,而string str = \"\" 給它分配長度爲空字符串的內存空間。 string str = null沒有string對象,string str = 「」有一個字符串對象。
string s3 = string.Empty;//反編譯發現,string.Empty就是在類構造函數中 Empty = "";
32.寫出一條Sql語句:取出表A中第31到第40記錄(SQLServer,以自動增加的ID做爲主鍵,注意:ID可能不是連續的。 (這就是SQL的分頁 oracle和sqlserver 和MS的不同)
答:解1: select top 10 * from A where id not in (select top 30 id from A)
解2: select top 10 * from A where id > (select max(id) from (select top 30 id from A )as A)
解答3:用ROW_NUMBER實現
解3:select a.* from (select rownum rn,t.* from A t) where rn<30 and rn>41
解4:select t.* from(select rownum rn t.* from A a where rownum<41) t where t. rn>30
解5:SELECT * FROM( select row_number() over(order by id DESC) as rowid,* from [MtPerInfo_tbl] ) t WHERE t.rowid BETWEEN 21 AND 30
my sql:
offset fetch next方式(SQL2012以上的版本才支持:推薦使用 )
select * from ArtistModels order by ArtistId offset 4 rows fetch next 5 rows only
--order by ArtistId offset 頁數 rows fetch next 條數 rows only ----
SELECT* FROM T_News order by Id OFFSET 2*5 ROW fetch next 5 rows only
33.面向對象的語言具備________性、_________性、________性
答:封裝、繼承、多態。
不要背,腦子中要有聯想。
35、什麼是code-Behind技術。
就是代碼隱藏,在ASP.NET中經過ASPX頁面指向CS文件的方法實現顯示邏輯和處理邏輯的分離,這樣有助於web應用程序的建立。好比分工,美工和編程的能夠個幹各的,不用再像之前asp那樣都代碼和html代碼混在一塊兒,難以維護。code-Behind是基於部分類技術實現的,在個人項目的三層代碼生成器中用到了部分類。
36、接口是一種引用類型,在接口中能夠聲明( a),但不能夠聲明公有的域或私有的成員變量。
a) 方法、屬性、索引器和事件;
b) 索引器和字段;
c) 事件和字段;
解讀:接口中不能聲明字段只能聲明方法,屬性、索引器和事件最終都編譯生成方法。由於字段屬於實現層面的東西,只有存取值的時候纔會用到字段,因此中接口中不能定義字段。
37. 在ADO.NET中,對於Command對象的ExecuteNonQuery()方法和ExecuteReader()方法,下面敘述錯誤的是(c)。
a) insert、update、delete等操做的Sql語句主要用ExecuteNonQuery()方法來執行;
b) ExecuteNonQuery()方法返回執行Sql語句所影響的行數。
c) Select操做的Sql語句只能由ExecuteReader()方法來執行;
d) ExecuteReader()方法返回一個DataReader對象; //SqlDataReader
拿SQLHelper實現一下。
38. 下列關於C#中索引器理解正確的是(c )
a) 索引器的參數必須是兩個或兩個以上
b) 索引器的參數類型必須是整數型
c) 索引器沒有名字
d) 以上皆非
39. 下面關於XML的描述錯誤的是(d)。
a) XML提供一種描述結構化數據的方法;
b) XML 是一種簡單、與平臺無關並被普遍採用的標準;
c) XML文檔可承載各類信息;
d) XML只是爲了生成結構化文檔;
40、如下的C#代碼,試圖用來定義一個接口:
public interface IFile
{
int A;
int delFile()
{
A = 3;
}
void disFile();
}
關於以上的代碼,如下描述錯誤的是(d )。
a) 以上的代碼中存在的錯誤包括:不能在接口中定義變量,因此int A代碼行將出現錯誤;
b) 以上的代碼中存在的錯誤包括:接口方法delFile是不容許實現的,因此不能編寫具體的實現函數;
c) 代碼void disFile();聲明無錯誤,接口能夠沒有返回值;
d) 代碼void disFile();應該編寫爲void disFile(){};
41、在ASP.NET中有Button控件myButton,要是單擊控件時,導航到其餘頁面http://www.abc.com, 正確的代碼爲( c)。
a) private void myButton_Click(object sender, System.EventArgs e){Redirect(「http://www.abc.com」);}
b) private void myButton_Click(object sender, System.EventArgs e){Request.Redirect(「http://www.abc.com」);}
c) private void myButton_Click(object sender, System.EventArgs e){Reponse.Redirect(「http://www.abc.com」);}
d) private void myButton_Click(object sender, System.EventArgs e){Request.Redirect(「http://www.abc.com」);return true;}
42. 聲明一個委託public delegate int myCallBack(int x); 則用該委託產生的回調方法的原型應該是(b )。
a) void myCallBack(int x) ;
b) int receive(int num) ;
c) string receive(int x) ;
d) 不肯定的;
43.StringBuilder 和 String 的區別?
答:String 在進行運算時(如賦值、拼接等)會產生一個新的實例,而 StringBuilder 則不會。因此在大量字符串拼接或頻繁對某一字符串進行操做時最好使用 StringBuilder,不要使用 String
44、.請敘述屬性與索引器的區別。 (*)
屬性 索引器
經過名稱標識。 經過簽名標識。
經過簡單名稱或成員訪問來訪問。 經過元素訪問來訪問。
能夠爲靜態成員或實例成員。 必須爲實例成員。
屬性的 get 訪問器沒有參數。 索引器的 get 訪問器具備與索引器相同的形參表。
屬性的 set 訪問器包含隱式 value 參數。 除了 value 參數外,索引器的 set 訪問器還具備與索引器相同的形參表。
46. 請解釋ASP。NET中的web頁面與其隱藏類之間的關係?
一個ASP.NET頁面通常都對應一個隱藏類,通常都在ASP.NET頁面的聲明中指定了隱藏類例如一個頁面Tst1.aspx的頁面聲明以下
<%@ Page language="c#" Codebehind="Tst1.aspx.cs" AutoEventWireup="false" Inherits="T1.Tst1" %>
Codebehind="Tst1.aspx.cs" 代表經編譯此頁面時使用哪個代碼文件
Inherits="T1.Tst1" 表用運行時使用哪個隱藏類
aspx頁面會編譯生成一個類,這個類從隱藏類繼承。
49、您在什麼狀況下會用到虛方法?它與接口有什麼不一樣?
答案:子類從新定義父類的某一個方法時,必須把父類的方法定義爲virtual
在定義接口中不能有方法體,虛方法能夠。
實現時,子類能夠不從新定義虛方法,但若是一個類繼承接口,那必須實現這個接口。
50. 不定項選擇:
(1) 如下敘述正確的是: B C
A. 接口中能夠有虛方法。B. 一個類能夠實現多個接口。 C. 接口不能被實例化。 D. 接口中能夠包含已實現的方法。
(2) 從數據庫讀取記錄,你可能用到的方法有:B C D
A. ExecuteNonQuery B. ExecuteScalar C. Fill D. ExecuteReader
(3).對於一個實現了IDisposable接口的類,如下哪些項能夠執行與釋放或重置非託管資源相關的應用程序定義的任務?(多選) ( ABCD )
A.Close B.Dispose C.Finalize
D.using E.Quit
(4)如下關於ref和out的描述哪些項是正確的?(多選) ( ACD )
A.使用ref參數,傳遞到ref參數的參數必須最早初始化。
B.使用out參數,傳遞到out參數的參數必須最早初始化。
C.使用ref參數,必須將參數做爲ref參數顯式傳遞到方法。
D.使用out參數,必須將參數做爲out參數顯式傳遞到方法。
51. 單項選擇:
(1)下列選項中,(C)是引用類型。
a)enum類型 b)struct類型 c)string類型 d)int類型
(2).關於ASP.NET中的代碼隱藏文件的描述正確的是(C)
a)Web窗體頁的程序的邏輯由代碼組成,這些代碼的建立用於與窗體交互。編程邏輯惟一與用戶界面不一樣的文件中。該文件稱做爲「代碼隱藏」文件,若是用C#建立,該文件將具備「.ascx.cs」擴展名。
b)項目中全部Web窗體頁的代碼隱藏文件都被編譯成.EXE文件。
c)項目中全部的Web窗體頁的代碼隱藏文件都被編譯成項目動態連接庫(.dll)文件。
d)以上都不正確。
(3).下列描述錯誤的是(D)
a)類不能夠多重繼承而接口能夠;
b)抽象類自身能夠定義成員而接口不能夠;
c)抽象類和接口都不能被實例化;
d)一個類能夠有多個基類和多個基接口;
52、DataReader和DataSet的異同?
DataReader使用時始終佔用SqlConnection,在線操做數據庫
每次只在內存中加載一條數據,因此佔用的內存是很小的
是隻進的、 只讀的
DataSet則是將數據一次性加載在內存中.拋棄數據庫鏈接..讀取完畢即放棄數據庫鏈接(非鏈接模式)
DataSet將數據所有加載在內存中.因此比較消耗內存...可是確比DataReader要靈活..能夠動態的添加行,列,數據.對數據庫進行 回傳更新操做(動態操做讀入到內存的數據)
53、public static const int A = 1;這段代碼有錯誤麼?
錯誤:const不能被修飾爲static ;由於定義爲常量 (const )後就是靜態的(static )。
54、傳入某個屬性的set方法的隱含參數的名稱是什麼?
value,它的類型和屬性所聲名的類型相同。
55、C#支持多重繼承麼?
類之間不支持,接口之間支持。類對接口叫作實現,不叫繼承。 類是爹、接口是能力,能有多個能力,但不能有多個爹。
56、C#中全部對象共同的基類是什麼?
System.Object
57、經過超連接怎樣傳遞中文參數?
答:用URL編碼,經過QueryString傳遞,用urlencode編碼 用urldecode解碼
58、string、String;int、Int32;Boolean、bool的區別
String、Int32、Boolean等都屬於.Net中定義的類,而string、int、bool至關於C#中對這些類定義的別名。CTS。
59、Server.Transfer和Response.Redirect的區別是什麼?(常考)
答:Server.Transfer僅是服務器中控制權的轉向,在客戶端瀏覽器地址欄中不會顯示出轉向後的地址;Response.Redirect則是徹底的跳轉,瀏覽器將會獲得跳轉的地址,並從新發送請求連接。這樣,從瀏覽器的地址欄中能夠看到跳轉後的連接地址。
Server.Transfer不能夠轉向外部網站,而Response.Redirect能夠。
Server.Execute效果和Server.Transfer相似,可是是把執行的結果嵌入當前頁面。
60、不是說字符串是不可變的嗎?string s="abc";s="123"不就是變了嗎?(傳智播客.Net培訓班原創模擬題)
String是不可變的在這段代碼中,s原先指向一個String對象,內容是 "abc",而後咱們將s指向"123",那麼s所指向的那個對象是否發生了改變呢?答案是沒有。這時,s不指向原來那個對象了,而指向了另外一個 String對象,內容爲"123",原來那個對象還存在於內存之中,只是s這個引用變量再也不指向它了。
61、是否能夠從一個static方法內部發出對非static方法的調用?
不能夠。由於非static方法是要與對象關聯在一塊兒的,必須建立一個對象後,才能夠在該對象上進行方法調用,而static方法調用時不須要建立對象,能夠直接調用。也就是說,當一個static方法被調用時,可能尚未建立任何實例對象,若是從一個static方法中發出對非static方法的調用,那個非static方法是關聯到哪一個對象上的呢?這個邏輯沒法成立,因此,一個static方法內部不能發出對非static方法的調用。
63、說出一些經常使用的類、接口,請各舉5個
要讓人家感受你對.Net開發很熟,因此,不能僅僅只列誰都能想到的那些東西,要多列你在作項目中涉及的那些東西。就寫你最近寫的那些程序中涉及的那些類。
經常使用的類:StreamReader、WebClient、Dictionary<K,V>、StringBuilder、SqlConnection、FileStream、File、Regex、List<T>
經常使用的接口:IDisposable、IEnumerable、IDbConnection、IComparable、ICollection、IList、IDictionary
要出乎意料!不要僅僅完成任務!筆試不是高考!到處要顯出牛!
說出幾個開源軟件?MySQL、Linux、 Discuz、Apache、Paint.Net、Android、Chrome、Notepad++……
開源項目有一些是開發包。開源軟件指的是能夠直接用的。Jquery、NPOI、ASP.Net MVC、Silverlight Toolkit、AJAX toolkit、json.net
得瑟!
65、編寫一個單例(Singleton)類。
參考複習ppt。
把構造函數設置爲private,設置一個public、static的對象實例
public FileManager
{
private FileManager(){}
public readonly static FileManager Instance = new FileManager();
}
擴展:搜「C# Singleton」,有線程安全的更牛B的實現
66、什麼是sql注入?如何避免sql注入?
用戶根據系統的程序構造非法的參數從而致使程序執行不是程序員指望的惡意SQL語句。使用參數化的SQL就能夠避免SQL注入。
詳細參考複習ppt。舉例子,擺事實!
1' or 1=1
67、數據庫三範式是什麼?
用本身的話解釋,而不是背概念。
傳智播客風格的非嚴謹卻一會兒明瞭的解答方式:
第一範式:字段不能有冗餘信息,全部字段都是必不可少的。
第二範式:知足第一範式而且表必須有主鍵。
第三範式:知足第二範式而且表引用其餘的表必須經過主鍵引用。
員工內部→本身的老大→外部的老大
記憶順序:本身內部不重複→別人引用本身→本身引用別人。
72、post、get的區別
get的參數會顯示在瀏覽器地址欄中,而post的參數不會顯示在瀏覽器地址欄中;
使用post提交的頁面在點擊【刷新】按鈕的時候瀏覽器通常會提示「是否從新提交」,而get則不會;
用get的頁面能夠被搜索引擎抓取,而用post的則不能夠;
用post能夠提交的數據量很是大,而用get能夠提交的數據量則很是小(2k),受限於網頁地址的長度。
用post能夠進行文件的提交,而用get則不能夠。
參考閱讀:http://www.cnblogs.com/skynet/archive/2010/05/18/1738301.html
解釋:引用類型和值類型的區別。
7八、下列哪一個名詞和WebService不直接相關?(B)(傳智播客.Net培訓班原創模擬題)
A、UDDI
B、GUID
C、WSDL
D、SOAP
WebService解決的三個問題:接口的自我描述;採用Http協議等常規協議,不用寫原始的Socket;基於Web服務器,不佔用80端口以外的端口。
UDDI用來自動發現WebService的協議(*)
SOAP和HTTP的關係:SOAP基於Http協議的,和普通網頁不一樣的是網頁返回HTML,SOAP則是符合SOAP協議的XML數據。
WSDL(WebService Defination Language)是對WebService上的方法名、參數進行描述的協議。對接口的自描述。
SOAP(Simple Object Access Protocol)是對參數、返回值以什麼樣的格式進行傳遞進行描述的協議。對報文的格式規範。
實際工做中應該是本身調用別人的WebService或者別人調用本身的WebService,溝通語言就是WSDL,拿到WSDL什麼都不用操心。
WebService是跨平臺、跨語言調用,能夠跨防火牆;缺點:效率低。因此適用於兩個非內部系統的通信(好比炒股軟件和證券交易所之間的通信)
WCF是對WebService、Socket、MQ等通信方式的一個統一,底層仍是採用這些通訊協議,能夠簡化這些程序的開發,不用再換不一樣通訊協議的時候重寫代碼而且學一堆新的技術。因此WCF和WebService不是一個競爭取代關係。
WCF是對.Net Remoting、WebService、MQ等通信方式的一個高級封裝,讓咱們開發不一樣通信協議的程序的時候很簡單,不用學更多的東西。並非替代.Net Remoting、WebService、MQ這些東西。
8一、.Net、ASP.Net、C#、VisualStudio之間的關係是什麼?(傳智播客.Net培訓班原創模擬題)
答:.Net通常指的是.Net Framework,提供了基礎的.Net類,這些類能夠被任何一種.Net編程語言調用,.Net Framework還提供了CLR、JIT、GC等基礎功能。
ASP.Net是.Net中用來進行Web開發的一種技術,ASP.Net的頁面部分寫在aspx 文件中,邏輯代碼一般經過Code-behind的方式用C#、VB.Net等支持.Net的語言編寫。
C#是使用最普遍的支持.Net的編程語言。除了C#還有VB.Net、IronPython等。
VisualStudio是微軟提供的用來進行.Net開發的集成開發環境(IDE),使用VisualStudio能夠簡化不少工做,不用程序員直接調用csc.exe等命令行進行程序的編譯,並且VisualStudio提供了代碼自動完成、代碼高亮等功能方便開發。除了VisualStudio,還有SharpDevelop、MonoDevelop等免費、開源的IDE,VisualStudio Express版這個免費版本。
8二、AJAX解決什麼問題?如何使用AJAX?AJAX有什麼問題須要注意?項目中哪裏用到了AJAX?(傳智播客.Net培訓班原創模擬題)
答:AJAX解決的問題就是「無刷新更新頁面」,用傳統的HTML表單方式進行頁面的更新時,每次都要將請求提交到服務器,服務器返回後再重繪界面,這樣界面就會經歷:提交→變白→從新顯示這樣一個過程,用戶體驗很是差,使用AJAX則不會致使頁面從新提交、刷新。
AJAX最本質的實現是在Javascript中使用XMLHttpRequest進行Http的請求,開發中一般使用UpdatePanel、JQuery等方式簡化AJAX的開發,UpdatePanel的方式實現AJAX最簡單,可是數據通信量比較大,由於要來回傳整個ViewState,並且不靈活,對於複雜的需求則可使用JQuery提供的ajax功能。
UpdatePanel的內部原理。
AJAX最重要的問題是沒法跨域請求(www.rupeng.com →so.rupeng.com),也就是沒法在頁面中向和當前域名不一樣的頁面發送請求,可使用在當前頁面所在的域的服務端作代理頁面的方式解決。
在如鵬網項目中發帖的時候顯示相關帖的功能、站內搜索項目中顯示搜索Suggestion、數據採集項目中都用到了AJAX。
常考:不用任何框架編寫一個AJAX程序。XHR:XmlHttpRequest。背也要背下來!
若是面試的時候談AJAX談到UpdatePanel的時候,就是NB的時候!!!先侃UpdatePanel的原理!引出爲何Dom操做的動態效果在用UpdatePanel提交刷新之後沒有了,以及CKEditor被套在UpdatePanel中提交之後也變成了textarea,爲何把Fileupload放到Updatepanel中沒法實現無刷新上傳。說成是公司內部的一個菜鳥用UpdatePanel遇到這樣問題,因爲我懂XHR、UpdatePanel的原理,因此輕鬆解決!UpdatePanel生成的上萬行JS腳本,不適合於互聯網項目。「WebForm怎麼可能把開發人員編程傻子呢!不明白原理苦命呀!仍是MVC好呀,MVC。。。。。。。」
多準備幾把斧子!上來找一切機會甩斧子!
8四、Application 、Cookie和 Session 兩種會話有什麼不一樣?
答:Application是用來存取整個網站全局的信息,而Session是用來存取與具體某個訪問者關聯的信息。Cookie是保存在客戶端的,機密信息不能保存在Cookie中,只能放小數據;Session是保存在服務器端的,比較安全,能夠放大數據。
談到Session的時候就侃Session和Cookie的關係:Cookie中的SessionId。和別人對比說本身懂這個原理而給工做帶來的方便之處。
8五、開放式問題:你常常訪問的技術類的網站是什麼?
博客園(www.cnblogs.com)、csdn、codeplex、codeproject、msdn文檔、msdn論壇(遇到問題先到網上搜解決方案,還不行就問同事,同事也解決不了就去MSDN論壇提問,必定能獲得解決)。Cnbeta.com。
8六、你對.net的GC的理解
GC是.Net的垃圾收集器,能夠進行內存資源的回收,程序員無需關心資源的回收,當一個對象沒有任何引用的時候就能夠被回收了。一個對象能夠被回收並不意味着必定會被當即回收,GC會選擇時機進行回收。能夠調用GC.Collect()讓GC當即回收。GC不能回收非託管資源,對於非託管資源通常都實現了IDisposable接口,而後使用using關鍵字進行資源的回收。
8七、請寫一個SQL語句:從user表中取出name列中的起始字符是「北京」的所有記錄
select * from [user] wherer name like '北京%'
8八、請你簡單的說明數據庫創建索引的優缺點
使用索引能夠加快數據的查詢速度,不過因爲數據插入過程當中會建索引,因此會下降數據的插入、更新速度,索引還會佔磁盤空間。
10六、不用JQuery等框架實現AJAX無刷新登陸。(常考)
提示:用純XMLHttpRequest實現。
10七、Http狀態碼各是什麼意思。
301(永久重定向)、302 :重定向
404 :頁面不存在
500:服務器內部錯誤
10八、 對html文本框進行賦值的JQuery語句,對html文本框進行取值的JQuery語句,對TextBox服務端控件進行取值的語句JQuery。
1十、Session有什麼重大BUG,微軟提出了什麼方法加以解決?(常考)
iis中因爲有進程回收機制,系統繁忙的話Session會丟失,IIS重啓也會形成Session丟失。這樣用戶就要從新登陸或者從新添加購物車、驗證碼等放到Session中的信息。能夠用State server或SQL Server數據庫的方式存儲Session不過這種方式比較慢,並且沒法捕獲Session的END事件。可是(必定要寫上,這樣纔夠拽)我認爲這不是Bug,只能說是In-Proc方式存儲Session的缺陷,缺陷是和Bug不同的,In-Proc方式存儲Session會由服務器來決定何時釋放Session,這是By Design,In-Proc方式不知足要求的話徹底能夠用StateServer和數據庫的方式。
StateServer還能夠解決集羣Session共享的問題。
配置StateServer的方法:
http://support.microsoft.com/kb/317604
http://blog.csdn.net/zj1103/archive/2008/09/14/2926773.aspx
111、asp.net中<%%>、<%=%>、<%#%>的區別是什麼
<%%>是執行<%%>中的C#代碼,<%=%>是將=後表達式的值輸出到Response中,<%#%>是數據綁定,通常用在ListView、GridView、Repeater等控件的綁定中。數據綁定分爲:Eval:單向綁定和Bind:雙向綁定。
11三、說說在軟件設計中你遇到的以空間換時間的例子?
參考回答:談Cache(緩存)、索引這些例子。用額外的磁盤、內存空間的消耗來提升執行速度。Lucene.Net也是一個例子。
11四、asp.net中的錯誤機制。(常考)
參考:
定製錯誤頁來將顯示一個友好的報錯頁面。
頁面中未捕獲同樣會觸發Page_Error(不經常使用),應用程序中的未捕獲異常會觸發Application_Error。經過HttpContext.Current.Server.GetLastError()、HttpContext.Current.Error;拿到未捕捉異常,記錄到Log4Net日誌中。
11五、不用中間變量交換兩個變量(常考)
i = i + j;//i=30
j = i - j;//j=10;
i = i - j;//i=20;
Console.WriteLine("i={0},j={1}",i,j);
另一個解決方案:位運算。
int a=5;
int b=6;
a=a^b;
b=b^a; //b^a至關於 b^a^b 也就是 b^a^b的值就是a了, 下邊相同
a=a^b;
下面的SQL題是常考題中的常考題,必須重視!!!!!!!!
11六、橫表、縱錶轉換(常考!!!)
1)縱表結構 TableA
Name |
Course |
Grade |
張三 |
語文 |
75 |
張三 |
數學 |
80 |
張三 |
英語 |
90 |
李四 |
語文 |
95 |
李四 |
數學 |
55 |
橫表結構 TableB
Name |
語文 |
數學 |
英語 |
張三 |
75 |
80 |
90 |
李四 |
95 |
55 |
0 |
先理解:
select Name,
(case Course when ‘語文‘ then Grade else 0 end) as 語文,
(case Course when ‘數學‘ then Grade else 0 end) as 數學,
(case Course when ‘英語‘ then Grade else 0 end) as 英語
from TableA
而後理解標準答案:
select Name, sum(case Course when ‘語文‘ then Grade else 0 end) as 語文, sum(case Course when ‘數學‘ then Grade else 0 end) as 數學, sum(case Course when ‘英語‘ then Grade else 0 end) as 英語 from TableA group by Name
2)、橫錶轉縱表的"SQL"示例
橫表結構: TEST_H2Z
ID 姓名 語文 數學 英語
1 張三 80 90 70
2 李四 90 85 95
3 王五 88 75 90
轉換後的表結構:
ID 姓名 科目 成績
1 張三 語文 80
2 張三 數學 90
3 張三 英語 70
4 李四 語文 90
5 李四 數學 80
6 李四 英語 99
7 王五 語文 85
8 王五 數學 96
9 王五 英語 88
橫錶轉縱表SQL示例:
SELECT 姓名,'語文' AS 科目,語文 AS 成績 FROM TEST_H2Z UNION ALL
SELECT 姓名,'數學' AS 科目,數學 AS 成績 FROM TEST_H2Z UNION ALL
SELECT 姓名,'英語' AS 科目,英語 AS 成績 FROM TEST_H2Z
ORDER BY 姓名,科目 DESC;
11七、刪除姓名、年齡重複的記錄(只保留Id最大的一條)(常考!!!)
Id name age salary
1 yzk 80 1000
2 yzk 80 2000
3 tom 20 20000
4 tom 20 20000
5 im 20 20000
//取得不重複的數據
select * from Persons where Id in ( SELECT MAX(Id) AS Expr1 FROM Persons GROUP BY Name, Age )
根據姓名、年齡分組,取出每組的Id最大值,而後將Id最大值以外的排除。
刪除重複的數據:
delete from Persons where Id not in ( SELECT MAX(Id) AS Expr1 FROM Persons GROUP BY Name, Age ) Select from Persons Where Id not in ( Select MAX(Id) AS Expr1 From PERSONS Group by name ,age )
儘量的得瑟!
11八、介紹幾個使用過的開源的項目
Lucene.net、NPOI、JQuery、ASP.Net AJAX toolkit、Quartz.Net、JqueryUI、ASP.Net MVC。在CodePlex、SourceForge等網站上有更多的開源項目。
11九、說出五個集合類
List、Dictionary、Set、Stack(先入後出)、Queue(先入先出)、Tree等。
解答:HashSet用於盛放不一樣的數據,相同的數據只保留一份
120有一個10個數的數組,計算其中不重複數字的個數。{3,5,9,8,10,5,3}
工程化的非最優解答:用HashSet或者List
int[] values = { 3, 5, 9, 8, 10, 5, 3 };
HashSet<int> set = new HashSet<int>();
foreach (int i in values)
{
set.Add(i);
}
Console.WriteLine(set.Count);
12二、下面是一個由*號組成的4行倒三角形圖案。要求:1、輸入倒三角形的行數,行數的取值3-21之間,對於非法的行數,要求拋出提示「非法行數!」;2、在屏幕上打印這個指定了行數的倒三角形。
*******
*****
***
*
123、一個文本文件含有以下內容:
4580616022644994|3000|趙濤
4580616022645017|6000|張屹
4580616022645090|3200|鄭欣夏
上述文件每行爲一個轉帳記錄,第一列表示賬號,第二列表示金額,第三列表示開戶人姓名。
建立一張數據庫表(MS SQLServer數據庫,表名和字段名自擬),請將上述文件逐條插入此表中。
127、說一下SQLServer中索引的兩種類型(常考!!!)
參考:聚簇(或者叫作彙集,cluster)索引和非聚簇索引。
字典的拼音目錄就是聚簇(cluster)索引,筆畫目錄就是非聚簇索引。這樣查詢「G到M的漢字」就很是快,而查詢「6劃到8劃的字」則慢。
聚簇索引是一種特殊索引,它使數據按照索引的排序順序存放表中。聚簇索引相似於字典,即全部詞條在字典中都以字母順序排列。聚簇索引實際上重組了表中的數據,因此你只能在表中創建一個聚簇索引。
當數據按值的範圍查詢時,聚簇索引就顯得特別有用。由於全部SQLServer都必需先找到所查詢範圍的第一行,而後依次下去,直到該範圍的最後一個值找到爲止,而且保證了全部其餘值也落在這個範圍內。舉一個例子,一個應用程序要查找首字母位於G和P之間的姓名列表,SQLServer首先找到以字母G開頭的名字,取出全部記錄,直到找到以字母P開頭的名字爲止,這種方法使得查詢過程很是高效。
進行大量數據改動的表不適宜用聚簇索引,由於SQLServer將不得不在表中維護行的次序。若是要索引的值極少,例如一個列包含的全都是1和0,建立聚簇索引就不是個好主意。若是表常常由一個指定的列來排序,該列將是簇索引的最佳候選列。這是由於表中的數據已經爲你排好序了。若是訪問一個表並使用BETWEEN、<、>、>=或<=操做符來返回一個範圍的值時,應該考慮使用聚簇索引。
128、滬江網網申題:
1)可否脫離VS用相似editplus的工具手寫代碼?你以爲如何才能提升代碼的效率和性能?
能夠,使用CSC.exe 來編譯.cs文件!
能夠根據業務流程、業務數據的特色進行優化,好比能夠採用緩存、索引、表驅動等來提高代碼的效率和性能,同時不要進行無心義的代碼優化,重點優化系統的性能瓶頸。
2).如何提升頁面的顯示速度?假如一個頁面的加載時間是10.89s,你會用什麼樣的方式進行優化?
回答要大氣!顯得很牛!
提示:分而治之的思想。
首先要找出問題所在,是服務器端運行的速度慢仍是服務器端到客戶端的下載慢仍是頁面在瀏覽器的加載速度慢。
若是是服務器端運行速度慢,則找是數據庫的緣由仍是算法的問題,若是是數據庫的問題則嘗試添加索引、優化SQL語句,若是是算法的問題,則優化算法。若是對於一些不常常改動的頁面可使用靜態頁技術!對於一些數據不須要及時更新的並且取數據的過程很是耗時可使用緩存。頁面中的內容能夠按需加載(好比說能夠像verycd網站的評論那樣當用戶須要看的時候再加載其內容),能夠在圖片須要顯示的時候再進行加載。
若是是服務器端到客戶端的下載慢則看是頁面體積過於臃腫仍是網絡問題,若是是頁面體積過於臃腫,則優化HTML代碼,去掉無用的標籤,壓縮JS、CSS,能夠用CSS Spirit技術將多個圖片放到一個圖片中,減小向服務器的請求。若是是網絡問題,則嘗試在不一樣的網絡、地區部署服務器,而後使用CDN技術加速訪問。
若是是頁面中的JavaScript運行復雜致使運行速度慢,則優化JavaScript。
webkaka:測網速。
如何處理百萬條數據的優化?
對於常常進行檢索的字段建立索引,對於常常進行範圍查詢的一個字段建立彙集索引;
當有大量數據進行插入的時候進行批量插入;
一些代碼用存儲過程進行重寫(當一個邏輯有多行SQL要執行的時候用存儲過程能夠優化速度,能夠避免客戶端和SQLServer之間屢次交互);
(*)集羣、讀寫分離;
(*)分區、分表;
3).在程序編碼的時候,你會對Sql注入漏洞的防範採起什麼樣的措施?
儘可能不要拼SQL語句!使用參數化查詢或存儲過程能夠防止SQL注入攻擊!在必須用SQL拼接的地方對用戶輸入的內容進行檢查、過濾。
4).你會採用什麼樣的策略和方法來實現系統緩存?
在ASP.NET中緩存有頁面緩存,數據源緩存,和一些本身定義的緩存!
對於那些整個頁面不常常變化的咱們可使用頁面緩存,而對於那些執行很是耗時的SQL語句而且數據的及時性要求不高的咱們可使用數據源緩存。
對於頁面緩存、數據源緩存等都不知足要求的狀況下采用直接操做HttpRuntime.Cache來自定義緩存策略。若是須要用多臺Web服務器做爲一個集羣來承載網站的狀況,則能夠部署專門的分佈式緩存服務器,好比Memcached。
5)網站想要實現文件防盜鏈的功能,說說你的解決方案。
讀取HTTP報文頭中的UrlReferrer在Application_BeginRequest中咱們能夠判斷用戶的請求是否來源於本網站。若是不是咱們能夠終止用戶的請求(Response.End();)!
6).有這樣一個功能需求,用戶新註冊的時候須要給他推薦3個好友,說說你的推薦算法
好比說相似豆瓣網咱們能夠根據用戶興趣來匹配,相似於人人網那些地區性比較比較強的網站咱們能夠根據用戶的地區來匹配。
7).若是給學英語的用戶設計一個在線應用,你會選擇什麼做爲切入點,簡述你的想法和理由。
英語學習資料的下載、在線答疑、用戶交流、在線英語角做爲切入點。
8).你眼中的滬江是怎樣的?談談你對滬江的理解
我眼中的滬江是爲那些愛好外語,須要學習外語人提供一個學校交流的平臺!
9).是否有如下相關開發經驗?若有請簡要說明開發狀況(有可看項目網址也請提供)。
a、lucene相關開發經驗
b、分佈式文件處理經驗
c、流媒體相關開發經驗
d、語音技術
e、高負載網站開發
f、手機相關開發
129、請編程遍歷WinForm頁面上全部TextBox控件並給它賦值爲string.Empty?
答:
foreach (System.Windows.Forms.Control control in this.Controls)
{
if (control is System.Windows.Forms.TextBox)
{
System.Windows.Forms.TextBox tb = (System.Windows.Forms.TextBox)control ;
tb.Text = String.Empty ;
}
}
132、
int i=2000;
object o=i;
i=2001;
int j=(int)o;
Console.WriteLine("i={0},o={1},j={2}",i,o,j);
輸出的結果是:
134.一個數組:1,1,2,3,5,8,13,21...+m,求第30位數是多少?用遞歸實現;(常考!!!)
寫遞歸要肯定兩個:遞歸的終止條件;遞歸表達式。
解答:總結遞歸規律:F(n)=F(n-2)+F(n-1) Fibonacci數列
static int F(int n) { if (n == 1) { return 1; } if (n == 2) { return 1; } return F(n - 2) + F(n - 1); }
非遞歸(有bug嗎?),遞歸算法的缺點:測試大數據
int n = Convert.ToInt32(Console.ReadLine()); if(n<=0) {Console.WRiteLine("必須大於0");return;} if(n==1) //時刻注意邊界值!!! { Console.WriteLine("1"); return; } int[] data =new int[n]; data[0] = 1; data[1] = 1; for(int i=2;i<n;i++) { data[i] = data[i-1]+data[i-2]; } Console.WriteLine(data[n-1]);
上面程序的時間複雜度爲O(n),空間複雜度爲O(n)
用BigInteger解決溢出的問題。
若是回答斐波那契數列:提到用非遞歸實現、注意邊界條件以及用BigInteger解決溢出問題!
題目:計算兩個很是大的整數的加法、乘法。用程序實現乘法、加法運算。最起碼把思路說出來,說本身寫不出來,可是工做中用BigInteger解決。
參考:
算法複雜度:時間複雜度:算法運行須要消耗的時間的數量級、空間複雜度:算法運行須要消耗的內存的數量級。
消耗的時間或者內存隨着問題規模的擴大而成正比增長,就是O(n)。
消耗的時間或者內存隨着問題規模的擴大而不變,就是O(1)。
消耗的時間或者內存隨着問題規模的擴大而n*n增長,就是O(n*n)
算法複雜度只考慮最差狀況(從一個數組中找出第一個大於10的數,時間複雜度爲O(n)),而且算法複雜度忽略常量和低階。把數組數一遍和數兩遍的時間複雜度都是O(n)。把長度爲n的數組數n/2遍的時間複雜度仍是O(n*n)。
上課時把數組先後顛倒的算法的時間複雜度爲O(n),空間複雜度爲O(1)。
136.ref與out的區別?
137.表A字段Id爲numberic(18,0),哪一個SQL語句是錯誤的:
select * from A where id='';
select * from A where id='13';
select * from A where id=null;
select * from A where id=' 13';
138.在SQLServer中求當前時間與2012-01-01 0:0:0相差的秒數?