C#面试参考有答案.docx
- 文档编号:9055659
- 上传时间:2023-05-16
- 格式:DOCX
- 页数:48
- 大小:53.61KB
C#面试参考有答案.docx
《C#面试参考有答案.docx》由会员分享,可在线阅读,更多相关《C#面试参考有答案.docx(48页珍藏版)》请在冰点文库上搜索。
C#面试参考有答案
c#面试问题
1.传入某个属性的set方法的隐含参数的名称是什么?
value,它的类型和属性所声名的类型相同。
2.如何在C#中实现继承?
在类名后加上一个冒号,再加上基类的名称。
3.C#支持多重继承么?
不支持。
可以用接口来实现。
4.被protected修饰的属性/方法在何处可以访问?
在继承或间接继承与这个类的子类中可以访问。
5.私有成员会被继承么?
会,但是不能被访问。
所以看上去他们似乎是不能被继承的,但实际上确实被继承了。
6.请描述一下修饰符protectedinternal。
被protectedinternal修饰的属性/方法只能在它的在同一个程序集(Assembly)中的子类被访问。
7.C#提供一个默认的无参数构造函数,当我实现了另外一个有一个参数的构造函数时候,还想保留这个无参数的构造函数。
这样我应该写几个构造函数?
两个,一旦你实现了一个构造函数,C#就不会再提供默认的构造函数了,所以需要手动实现那个无参数构造函数。
8.C#中所有对象共同的基类是什么?
System.Object.
9.重载和覆写有什么区别?
重载提供了对一个方法签名的不同参数调用的实现。
覆写提供了子类中改变父类方法行为的实现。
10.在方法定义中,virtual有什么含意?
被virtual修饰的方法可以被子类覆写。
11.能够将非静态的方法覆写成静态方法么?
不能,覆写方法的签名必须与被覆写方法的签名保持一致,除了将virtual改为override。
12.可以覆写私有的虚方法么?
不可以,甚至子类中无法访问父类中的私有方法。
13.能够阻止某一个类被其他类继承么?
可以,使用关键字sealed。
14.能够实现允许某个类被继承,但不允许其中的某个方法被覆写么?
可以,标记这个类为public,并标记这个方法为sealed。
15.什么是抽象类(abstractclass)?
一种不可以被实例化的类。
抽象类中一般含有抽象方法,当然也可有具体实现。
继承类只有实现过所有抽象类的抽象方法后才能被实例化。
16.何时必须声明一个类为抽象类?
当这个类中包含抽象方法时,或是该类并没有完全实现父类的抽象方法时。
17.接口(interface)是什么?
只含有共有抽象方法(publicabstractmethod)的类。
这些方法必须在子类中被实现。
18.为什么不能指定接口中方法的修饰符?
接口中的方法用来定义对象之间通信的契约,指定接口中的方法为私有或保护没有意义。
他们默认为公有方法。
19可以继承多个接口么?
当然。
20.那么如果这些接口中有重复的方法名称呢?
这种情况中你可以决定如何实现。
当然需要特别得小心。
但是在编译环节是没有问题的。
21.接口和抽象类的区别是什么?
接口中所有方法必须是抽象的,并且不能指定方法的访问修饰符。
抽象类中可以有方法的实现,也可以指定方法的访问修饰符。
22.如何区别重载方法?
不同的参数类型,不同的参数个数,不同的参数顺序。
23.const和readonly有什么区别?
const关键字用来声明编译时常量,readonly用来声明运行时常量。
24.System.String和System.StringBuilder有什么区别?
System.String是不可变的字符串。
System.StringBuilder存放了一个可变的字符串,并提供一些对这个字符串修改的方法。
25..NET方向高级开发人员面试时应该事先考虑的问题
(澄清一下,我发帖的目的不是用来专门给人评价这些问题的好坏的,实际上我所在的公司就考察这些问题。
而能够基本上答出来的可以说百里挑一。
如果各位觉得这些问题很简单,那么基本上在.NET面试环节就没有什么问题了,同时欢迎提供一些更多的问题。
如果还有些不知道,那么不妨静下心来思考一下(或者用15秒搜索一下),没有必要花太多时间来攻击题目的合理性。
毕竟,几乎所有的面试都是这样。
如果没法改变,我们还是学着适应吧。
)
如果你的简历上面说“精通.NET”,那么下面的问题应该大都可以给出较完美的答案。
我会稍后给出一些我的想法,还请各位不吝指正并参与讨论。
也欢迎提供给我更多的问题。
里还有一些基础问题:
注:
对于每个判断是非问题,都要考虑“为什么”与“为什么不”。
26.Thread和Process之间有什么区别?
.NET新引入了ApplicationDomain的概念,这样他们三个之间有什么区别?
引入了ApplicationDomain会带来一些潜在的问题么?
27WindowsService与普通的EXE在执行过程中有什么区别?
28.一个进程可以访问的Windows地址空间有多大?
等于系统的虚拟内存大小么?
这两方面将对系统的设计产生什么样的影响?
29.EXE和DLL之间的区别是什么?
在系统设计中应该如何选择使用它们?
普通的EXE与.NETEXE的执行过程有什么不同?
30.什么是弱类型,什么是强类型?
在系统设计中应该首先考虑使用哪种类型?
31.PDB文件是作什么用的?
里面包含了什么信息?
32.CycloramicComplexity是什么?
为什么它很重要?
33.为创建一个criticalsection以访问某个变量书写一个标准的lock()并加上doublecheck。
为某个对象实现标准的Dispose模式。
34.什么是FullTrust?
存在于GAC中的assembly拥有FullTrust么?
35.下面这个命令是做什么的?
gacutil/l|find/i“system”
36.下面这个命令是作什么的?
sn-tsomething.dll
37.跨防火墙的DCOM必须打开哪个端口?
端口135是用来做什么的?
38.有什么办法可以与现有unmanagedcode集成?
在集成的时候应该考虑什么问题?
39.简要解释一下OOP与SOA都是用来作什么的?
40.XmlSerializer是如何工作的?
进程运行XmlSerializer时候需要什么样的ACL权限?
在系统设计时,何时应该使用trycatch?
何时需要避免使用?
41.Debug.Write()和Trace.Write()之间有什么区别?
二者分别应该用于何处?
42.DebugBuild和ReleaseBuild有什么区别?
在执行效率上有什么明显的区别么?
43.JIT是针对Assembly还是Method发生的?
解释一下为什么.NET的设计者要这样做?
简要描述一下GC的执行过程。
44.应该如何选择使用abstractclass还是interface?
45.在设计一个自定义类型时应如何选择使用ValueType还是ReferenceType?
46.对于ValueType和ReferenceType,a.Equals(b)的默认实现方式有什么不同?
47..NET中为什么不提供默认的deepcopy?
如果需要,要如何实现deepcopy?
48.相对于.NET1.1,.NET2.0为了避免过度的boxing/unboxing造成的系统开销提供了哪些支持?
49.String是ValueType还是ReferenceType?
为什么.NET中的String对象被设置成immutable?
C#基本问题列表——面试通常题(转)
1、Stringstr=newString("a")和Stringstr="a"有什么区别?
Stringstr="a";这个只是一个引用,内存中如果有“a"的话,str就指向它,如果没有才创建如果你以后还用到"a"这个字符串的话并且是这样用:
Stringstr1="a";Stringstr2="a";Stringstr2="a";这4个变量都共享一个字符串"a"而Stringstr=newString("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)的区别?
之一:
抽象方法仅有声明,而没有任何实现,如abstractsomeMethod();,虚方法却不能如此
之二:
子类继承父类,可以对父类中的虚方法进行重写、覆盖、不处理三种处理(见5),对抽象方法却必须实现
5、子类对父类中虚方法的处理有重写(override)和覆盖(new),请说明它们的区别?
有父类ParentClass和子类ChildClass、以及父类的虚方法VirtualMethod。
有如下程序段:
ParentClasspc=newChildClass();
pc.VirtualMethod(...);
如果子类是重写(override)父类的VirtualMethod,则上面的第二行语句将调用子类的该方法
如果子类是覆盖(new)父类的VirtualMethod,则上面的第二行语句将调用父类的该方法
6、抽象类(abstract)和接口(interface)的区别
抽象类可以有自己的实现,接口却仅有声明,可以有自己的静态数据字段;
java和C#中可以实现多个接口,却只能继承一个抽象类(或者非抽象类)(单继承,和c++的多继承不同);
使用Override和New关键字控制版本
C#语言经过专门设计,以便不同库中的基类与派生类之间的版本控制可以不断向前发展,同时保持向后兼容。
这具有多方面的意义。
例如,这意味着在基类中引入与派生类中的某个成员具有相同名称的新成员在C#中是完全支持的,不会导致意外行为。
它还意味着类必须显式声明某方法是要重写一个继承方法,还是一个仅隐藏具有类似名称的继承方法的新方法。
C#允许派生类包含与基类方法名称相同的方法。
基类方法必须定义为virtual。
如果派生类中的方法前面没有new或override关键字,则编译器将发出警告,该方法将有如存在new关键字一样执行操作。
如果派生类中的方法前面带有new关键字,则该方法被定义为独立于基类中的方法。
如果派生类中的方法前面带有override关键字,则派生类的对象将调用该方法,而不调用基类方法。
可以从派生类中使用base关键字调用基类方法。
override、virtual和new关键字还可以用于属性、索引器和事件中。
默认情况下,C#方法不是虚方法--如果将一种方法声明为虚方法,则继承该方法的任何类都可以实现其自己的版本。
若要使方法成为虚方法,必须在基类的方法声明中使用virtual修饰符。
然后,派生类可以使用override关键字重写基虚方法,或使用new关键字隐藏基类中的虚方法。
如果override关键字和new关键字均未指定,编译器将发出警告,并且派生类中的方法将隐藏基类中的方法。
7.设计模式概述
设计模式从本质上说是一种规则,从形式上说,分为创建型、结构型、行为型。
设计模式的应用是为了实现软件设计中的几个原则,其中一个重要原则是:
减少模块之间的耦合程度。
为了确保这个目的,在设计一个类时,要针对接口,而非实现。
(ProgrammingtoanInterface,notanImplementation)设计的时候只关心类的接口,编程的时候可以先实现一个简单的接口,供别的模块调用。
使用一个类的时候只对接口工作,不关心具体的实现,也不关心具体的类型。
这样也符合人类认识世界的规律,一般说来人们总是先了解一个事情的大概情况,比如,我们先了解一台电视机的大概功能,然后才能了解每个功能具体是怎样实现的。
开始的时候不提供实现,正是为了以后能够最大限度的实现。
设计模式不受语言的限制,使用.net或者java更容易实现。
8. 工厂模式(Factory)
工厂模式属于一种创建型模式(Creational)。
同样属于创建型模式的还有单件模式(Singleton),以后有机会再说。
工厂模式的要点:
1:
存在一个创建对象的工厂;
2:
调用者从工厂中取得某些对象;
3:
由工厂决定如何创建对象;
4:
客户不知道对象是如何生成的。
举一个例子,下面的类视图:
Namer对象是FirstFirst和LastFirst的基类,用户调用Namer类的时候,不直接new出Namer类或者他的子类,而是使用NameFactory的getName方法得到具体的对象。
这样在用户就不用关心自己正在使用的是哪一个Namer,正在调用哪一个方法。
用户只针对Namer进行工作,而不用关心具体的类型。
在实际工程中可以将Namer类的子类的构造函数只对NameFactory开放,进一步限制程序员。
C#代码如下:
1:
Namer的实现
usingSystem;
namespaceNameFactory
{//////SummarydescriptionforNamer./////BaseclassforgettingsplitnamespublicclassNamer{
//partsstoredhereprotectedstringfrName,lName;
//returnfirstnamepublicstringgetFrname()
{
returnfrName;
}
//returnlastnamepublicstringgetLname(){
returnlName;
}
}
}
2:
FirstFirst类的实现
usingSystem;
namespaceNameFactory
{
//////SummarydescriptionforFirstFirst.///publicclassFirstFirst:
Namer
{
publicFirstFirst(stringname)
{
inti=name.IndexOf("");
if(i>0){
frName=name.Substring(0,i).Trim();
lName=name.Substring(i+1).Trim();
}
else{
lName=name;
frName="";
}
}
}
}
3:
LastFirst类的实现
usingSystem;
namespaceNameFactory
{//////SummarydescriptionforLastFirst.///publicclassLastFirst:
Namer
{
publicLastFirst(stringname){
inti=name.IndexOf(",");
if(i>0){
lName=name.Substring(0,i);
frName=name.Substring(i+1).Trim();
}
else{
lName=name;
frName="";
}
}
}
}
4:
NameFactory,工厂的实现
usingSystem;
namespaceNameFactory
{
//////SummarydescriptionforNameFactory.///publicclassNameFactory{
publicNameFactory(){}
publicNamergetName(stringname){
inti=name.IndexOf(",");
if(i>0)
returnnewLastFirst(name);
elsereturnnewFirstFirst(name);
}
}
}
5:
调用者,一个窗体,如图:
按钮的响应事件代码如下:
Namernm=nameFact.getName(txName.Text);
txFirst.Text=nm.getFrname();
txLast.Text=nm.getLname();
}
privatevoidbtCompute_Click(objectsender,System.EventArgse){
程序并不复杂,运行不运行无所谓,关键是要搞清楚Factory所起的作用:
他隐藏了Namer类的创建细节,调用者始终不知道他创建的是哪一个类,也不需要关心他调用的方法是哪一个子类的。
如果以后的程序的需求发生改动,比如:
某国的人不仅有FirstName和LastName,还有MidName,就可以很方便的进行扩充,添加一个Namer的子类,修改一下Factory。
调用者甚至不知道有新加了一种Namer的类型。
实际的应用
举一个简单的例子:
工程中需要使用多种数据库,Oracle、SQLServer、Sybase,为这些数据库建立了各自的连接和查询操作的类,这些类有一个共同的基类BaseConn。
可以建立一个ConnFactory类,用于根据不同情况产生具体的类。
调用者不必关心自己调用的是谁。
大大简化了业务代码。
实际的使用例子还有很多。
单件模式(Singleton)
是一个非常简单的模式,这是我第一个理解并且能运用的模式。
有时候模式的复杂程度并不在于本身,而是由于他的应用目的。
最初的时候面对一个模式经常充满了困惑,一个简单的调用为什么要搞的如此复杂?
为什么要建立这么多类,只是为了打开一个文件。
通常说来学习一个模式是一个接受、认可、领会的过程。
接受:
了解模式的结构,了解实例的意义;认可:
认可该模式在实际工程中的作用和可行性;领会:
将模式应用到开发过程中。
而模式的应用目的说到底无非是为了降低模块之间在时间和空间上的耦合程度,以此提高模块的复用性,降低出错的概率。
单件模式
Singleton模式是一个较为简单的模式,下面的代码就可以建立一个Singlton模式的例子,这是一个写系统日志的类。
{
//申明一个静态的变量,类型为类本身privatestaticLogWriter_instance=null;
//将类的构造函数私有化,使得这个类不可以被外界创建privateLogWriter()
{
}
//提供静态的方法,创建类的实例publicstaticLogWriterGetInstance()
{
if(_instance==null)
{
_instance=newLogWriter();
}
return_instance;
}
//下面实现类的其他功能//....
}
publicclassLogWriter
调用者不可以通过new的形式得到Singleton的实例,调用的例子如下:
LogWriterlog=LogWriter.GetInstance();
log.Debug("helloworld");
实际应用
很容易想象,单件模式适用于下面的情况:
整个系统中某个对象是唯一的,或者是有固定数量的。
比如数据库连接,配置文件,等等……
模式是一种程序员间的约定术语,语言可以成为思维的基础。
有了这样的语言,一些复杂的概念就变得容易交流了。
比如设计人员只要说到,某个类是一个单件模式,是一个Singleton,程序员听见以后就至少应该明白这个类的调用方式了,而不用再详细的说明。
1、请你自我介绍一下你自己,
回答提示:
一般人回答这个问题过于平常,只说姓名、年龄、爱好、工作经验,这些在简历上都有,其实,企业最希望知道的是求职者能否胜任工作,包括:
最强的技能、最深入研究的知识领域、个性中最积极的部分、做过的最成功的事,主要的成就等,这些都可以和学习无关,也可以和学习有关,但要突出积极的个性和做事的能力,说得合情合理企业才会相信。
企业很重视一个人的礼貌,求职者要尊重考官,在回答每个问题之后都说一句“谢谢”。
企业喜欢有礼貌的求职者。
2、你觉得你个性上最大的优点是什么?
回答提示:
沉着冷静、条理清楚、立场坚定、顽强向上。
乐于助人和关心他人、适应能力和幽默感、乐观和友爱。
我在北大青鸟经过一到两年的培训及项目实战,加上实习工作,使我适合这份工作。
我相信我能成功。
3、说说你最大的缺点?
回答提示:
这个问题企业问的概率很大,通常不希望听到直接回答的缺点是什么等,如果求职者说自己小心眼、爱忌妒人、非常懒、脾气大、工作效率低,企业肯定不会录用你。
绝对不要自作聪明地回答“我最大的缺点是过于追求完美”,有的人以为这样回答会显得自己比较出色,但事实上,他已经岌芨可危了。
企业喜欢求职者从自己的优点说起,中间加一些小缺点,最后再把问题转回到优点上,突出优点的部分。
企业喜欢聪明的求职者。
4、你对加班的看法?
回答提示:
实际上好多公司问这个问题,并不证明一定要加班。
只是想测试你是否愿意为公司奉献。
回答样本:
如果是工作需要我会义不容辞加班。
我现在单身,没有任何家庭负担,可以全身心的投入工作。
但同时,我也会提高工作效率,减少不必要的加班
5、你对薪资的要求?
回答提示:
如果你对薪酬的要求太低,那显然贬低自己的能力;如果你对薪酬的要求太高,那又会显得你分量过重,公司受用不起。
一些雇主通常都事先对求聘的职位定下开支预算,因而他们第一次提出的价钱往往是他们所能给予的最高价钱。
他们问你只不过想证实一下这笔钱是否足以引起你对该工作的兴趣。
回答样本一:
“我对工资没有硬性要求。
我相信贵公司在处理我的问题上会友善合理。
我注重的是找对工作机会,所以只要条件公平,我则不会计较太多
回答样本二:
我受过系统的软件编程的训练,不需要进行大量的培训。
而且我本人也对编程特别感兴趣。
因此,我希望公司能根据我的情况和市场标准的水平,给我合理的薪水。
回答样本
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C# 面试 参考 答案