當前位置:學問谷 >

職場範例 >面試 >

經典C#面試題

經典C#面試題

S1 C#:

經典C#面試題

Ch1:

1、= = 與Equals方法的區別?

對於值類型:由於值類型是存儲在棧中,兩者都是比較的是兩個變量的在棧中的值是否相等。

對於引用類型:引用類型是在堆一個存儲引用,指向堆中的某個具體值。= =判斷引用地址,equals判斷值

2、Java中的switch於C#中的switch的區別

Java中的switch:只能判斷int, short及比int所佔字節還少的類型

C#中的switch:可以判斷string及比string所佔字節少的類型

Ch2:

1、 冒泡排序(c#)口訣

int[] numbers ={ 49, 12, 65, 45, 88, 54 };

//排序前

eLine("排序前:");

foreach (int i in numbers)

{

e(i + " ");

}

//冒泡排序

for (int i = 0; i < th; i++ )

{

for (int j = 0; j < th - 1 - i; j++ )

{//將最大數交換到最後

if(numbers[j] > numbers[j+1])

{

int temp = numbers[j];

numbers[j] = numbers[j + 1];

numbers[j + 1] = temp;

}

}

}

//排序後

eLine("n排序後:");

foreach (int i in numbers)

{

e(i + " ");

}

2、 分別寫出四種循環語法

for(int i=0;i

3、 編程求數組中的最大數,打印所有的水仙花數,打印九九乘法表

求最大數:int[] numbers ={ 49, 12, 65, 45, 88, 54 };

int max = 0;

for (int i = 0; i < th-1; i++ )

{

if(numbers[i] > numbers[i+1])

{

max = numbers[i];

}

}

eLine("最大數為:"+max);

水仙花數:for (int i = 100; i < 1000; i++ )

{

int a = i % 10; //個位數

int b = i % 100; //十位數

b = b / 10;

int c = i / 100; //百位數

int number = (int)(a, 3) + (int)(b, 3) + (int)(c, 3);

if(number == i)

{

e(i + " ");

}

}

打印九九乘法表:for (int i = 1; i <= 9; i++ )

{

for (int j= 1; j <= i; j++)

{

e("{0}×{1}={2}t", j, i, i * j);

}

eLine();

}

Ch3:

1、 命名空間的含義:包,便於管理

2、 引用傳遞和值傳遞的區別:主要是相對於值類型,用引用傳遞加ref,就可實現其值真正的改變。值傳遞,當調用方法結束後,則不會改變值。

3、 請寫出String的常用方法(10個),並描述功能

Equals():判斷值相等 Split():以…分割每個字符為string[]數組 IndexOf():返回指定字符的索引

Concat():連接,相當於’+’號 Trim():忽略前後空格 ToUpper():轉換為大寫 ToLower():轉換為小寫

StartsWith():開頭字符是否匹配 SubString():截取字符串 ToCharArray():轉換為char[]數組

4、 分別寫出數據類型轉換(至少四種)的方法,代碼舉例

顯示轉換:int i=(int)12.9;

隱式轉換:double d=12;

int/double/e ()轉換:string s=”13”; int i=e(s);

convert:int x = 13; double d = uble(x);

Ch4:

1、 partial關鍵字的含義

partial局部類型允許我們將一個類、結構或接口分成幾個部分,分別實現在幾個不同的文件中。

適用於以下情況:(1) 類型特別大,不宜放在一個文件中實現。(2) 一個類型中的一部分代碼為自動化工具生成的代碼,不宜與我們自己編寫的代碼混合在一起。(3) 需要多人合作編寫一個類

2、 Windows窗體的生命週期常用事件有哪些?

Initialize, Load, Activated(窗體被激活時), Deactivate(窗體被停用時), FormClosed, FormClosing

3、 寫出常用的控件鍵盤事件和鼠標事件

鍵盤事件:KeyDown, KeyUp, Keypress

鼠標事件:Click,DoubleClick,MouseClick,MouseDown,MouseEnter,MouseHover,MouseLeave,MouseMove,MouseUp

4、 請寫出MessageBox常用的四種類型,以及返回值類型

(“消息內容”); 返回類型:DialogResult

(“消息內容”,”標題”); 返回類型:DialogResult

(“消息內容”,”標題”); 返回類型:DialogResult

(“消息內容”,”標題”, MessageBoxButtons按鈕類型); 返回類型:DialogResult

(“消息內容”,”標題”, MessageBoxButtons按鈕類型, MessageBoxIcon圖標類型

); 返回類型:DialogResult

Ch5:

1、 anchor和dock的區別

anchor(錨定):距離容器邊緣的距離,當控件錨定到某個邊緣時,與指定邊緣最接近的控件邊緣與指定邊緣之間的距離將保持不變。

dock(停靠):將控件停靠在窗體或容器的邊緣,距離為0px

2、 如何創建一個MDI窗體(步驟),即多文檔窗體

1)設置子窗體:子窗體名稱 form = new Form(); arent=this(父窗體); ();

2)設置父窗體屬性:isMdiContainer=true;

3、 模式窗體和非模式窗體的區別

模式窗體:Dialog();有返回值:DialogResult;程序會中斷,主窗體不能激活,必須關閉模式窗體才能激活主窗體, 只能show出一個

非模式窗體: (); 無返回值,程序不會中斷;可以show出多個

4、 使用第三方類傳遞窗體間的數據(代碼演示)

public class UserHelpper

{

public static string loginId = ""; //用户名

public static string loginType = ""; //登錄類型

}

Ch6:

1、 重要組件(那幅圖6.2)

ramework和DateSet

2、 數據提供者程序有哪些

3、 連接字符串的寫法(兩種)

"Data Source=.SQLEXpRESS;Initial Catalog=數據庫名;Integrated security=true;"

"server=.sqlexpress; database=數據庫名; uid=用户名; password=密碼"

4、 Connection對象的屬性和方法:數據庫連接對象

屬性:state 連接狀態, DataBase 獲取連接對象的數據庫名稱, DataSource連接對象的實例名

方法:Open()/Close() 打開/關閉數據庫, Dispose() 釋放連接資源, ChangeDatabase() 為打開的當前連接對象更改數據庫名。

5、 異常處理各關鍵字的作用

try:可能發生異常的代碼塊

catch:捕獲到何種異常,如何去處理, 可以跟多個catch塊,但子類異常必須寫在父類異常的前面

finally:不管有沒有異常都將執行的代碼塊

6、 Command對象的屬性和方法:SQL語句執行命令

屬性:CommandText獲取或設置要對數據源執行的 Transact-SQL 語句、表名或存儲過程。 Connection獲取或設置 SqlCommand 的此實例使用的' SqlConnection

方法:ExecuteNonQuery() 執行增,刪,改語句,並返回受影響行數; ExecuteScalar() 執行查詢,返回結果的第一行第一列,忽略其他列或行; ExecuteReader() 執行查詢,返回DataReader對象

Ch7:

1、 DataReader對象的主要屬性和方法

屬性:HasRows 有沒有讀取到DataReader中的數據;IsClosed 是否已關閉DataReader對象

方法:Read() 讀取一行數據;GetString()/GetDouble()… 獲取何種類型的數據值; Close() 關閉DataReader對象; IsDBNull() 獲取一個值,用於指示列中是否包含不存在的或缺少的值

2、 請寫出獲取並使用DataReader對象的步驟

1) 建立數據庫連接conn=new …Connection(…); 2)創建Command對象cmd= new …Command(sql, conn); 3)執行SQL查詢命令sdr=cmd. ExecuteReader(); 4)處理數據 while(()){int i=nt(0);}

Ch8:

1、 請寫出DataSet(臨時數據庫)的內部結構(圖8.2)

2、 寫出填充一個DataSet的步驟

3、 數據集的工作原理(圖8.3)

4、 如何將數據集中的數據保存到數據庫,請寫出步驟

S2 深入

Ch1:

1、 畫出框架的結構(圖1.7)

Framework類庫:(Web和Web Service)、WinForms、和XML類、基本框架類。

CLR:CLS和CTS。

2、 解釋CTS(Common Type System通用類型系統)和CLS(Common Language Specification公共語言規範)的含義

CTS:解決不同語言的數據類型不同的問題。

CLS:實現多種語言之間的互操作性。

3、


C#編譯器


畫出編譯過程(圖1.8)


C#代碼



Microsoft中間語言

(MSIL)



平台專用代

標籤: 面試題
  • 文章版權屬於文章作者所有,轉載請註明 https://xuewengu.com/flzc/mianshi/ngn9q.html