ADotNet面试宝典.docx
- 文档编号:23951200
- 上传时间:2023-05-22
- 格式:DOCX
- 页数:48
- 大小:56.10KB
ADotNet面试宝典.docx
《ADotNet面试宝典.docx》由会员分享,可在线阅读,更多相关《ADotNet面试宝典.docx(48页珍藏版)》请在冰豆网上搜索。
ADotNet面试宝典
这套面试题主要目的是帮助那些还没有.Net软件开发实际工作经验,而正在努力寻找.Net软件开发工作的朋友在笔试时更好地赢得笔试和面试。
由于这套面试题涉及的范围很泛,很广,很杂,大家不可能一天两天就看完和学完这套面试宝典,即使你已经学过了有关的技术,那么至少也需要一个月的时间才能消化和掌握这套面试宝典,所以,大家应该早作准备,从拿到这套面试宝典之日起,就要坚持在每天闲暇之余学习其中几道题目,日积月累,等到出去面试时,一切都水到渠成,面试时就自然会游刃有余了。
回答问题的思路:
先正面叙述一些基本的核心知识,然后描述一些特殊的东西,最后再来一些锦上添花的东西。
要注意有些不是锦上添花,而是画蛇添足的东西,不要随便写上。
把答题像写书一样写。
我要回答一个新技术的问题大概思路和步骤是:
我们想干什么,干这个遇到了什么问题,现在用什么方式来解决。
其实我们讲课也是这样一个思路。
例如,讲ajax时,我们希望不改变原来的整个网页,而只是改变网页中的局部内容,例如,用户名校验,级联下拉列表,下拉树状菜单。
用传统方式,就是浏览器自己直接向服务器发请求,服务器返回新页面会盖掉老页面,这样就不流畅了。
答题时,先答是什么,再答有什么作用和要注意什么(这部分最重要,展现自己的心得)
答案的段落分别,层次分明,条理清楚都非常重要,从这些表面的东西也可以看出一个人的习惯、办事风格、条理等。
要讲你做出答案的思路过程,或者说你记住答案的思想都写下来。
把答题想着是辩论赛。
答题就是给别人讲道理、摆事实。
答题不局限于什么格式和形式,就是要将自己的学识展现出来!
别因为人家题目本来就模棱两可,你就心里胆怯和没底气了,不敢回答了。
你要大胆地指出对方题目很模糊和你的观点,不要把面试官想得有多高,其实他和你就是差不多的,你想想,如果他把你招进去了,你们以后就是同事了,可不是差不多的吗?
关于就业薪水,如果你是应届生,那不能要高工资,要拿高工资,就去中关村!
少数人基础确实很好,在校期间确实又做过一些项目,那仍然是可以要到相对高的工资的。
初级程序员薪水:
2000-4500
中级程序员薪水:
4000-7000
高级程序员薪水:
7000以上
公司招聘程序员更看重的要用到的编码技术、而不是那些业务不太相关的所谓项目经历:
1.公司想招什么样的人2.公司面试会问什么,.3.简历怎么写4怎样达到简历上的标准(培训中心教项目的目的)
对于一些公司接到了一些项目,想招聘一些初中级的程序员过来帮助写代码,完成这个项目,你更看重的是他的专业技术功底,还是以前做过几个项目的经历呢?
我们先排除掉那些编码技术功底好,又正好做过相似项目的情况,实际上,这种鱼和熊掌兼得的情况并不常见。
其实公司很清楚,只要招聘进来的人技术真的很明白,那他什么项目都可以做出来,公司招人不是让你去重复做你以前的项目,而是做一个新项目,业务方面,你只要进了项目团队,自然就能掌握。
所以,大多数招聘单位在招聘那些编码级别的程序员时也没指望能招聘到做过类似项目的人,也不会刻意去找做过类似项目的人,用人单位也不是想把你招进,然后把你以前做过的项目重做一遍,所以,用人单位更看重招进来的人对要用到的编码技术的功底到底怎样,技术扎实不扎实,项目则只要跟着开发团队走,自然就没问题。
除非是一些非常专业的行业,要招聘特别高级的开发人员和系统分析师,招聘单位才特别注重他的项目经验和行业经验,要去找到行业高手,公司才关心项目和与你聊项目的细节,这样的人通常都不是通过常规招聘渠道去招聘进来的,而是通过各种手段挖过来的,这情况不再我今天要讨论的范围中。
技术学得明白不明白,人家几个问题就把你的深浅问出来了,只要问一些具体的技术点,就很容易看出你是真懂还是假懂,很容看出你的技术深度和实力,所以,技术是来不得半点虚假的,必须扎扎实实。
由于项目的种类繁多,涉及到现实生活中的各行各业,什么五花八门的业务都有,例如,酒店房间预定管理,公司车辆调度管理,学校课程教室管理,超市进销存管理,知识内容管理,等等……成千上万等等,但是,不管是什么项目,采用的无非都是我们学习的那些目前流行和常用的技术。
技术好、经验丰富,则项目做出来的效率高些,程序更稳定和更容易维护些;技术差点,碰碰磕磕最后也能把项目做出来,无非是做的周期长点、返工的次数多点,程序代码写得差些,用的技术笨拙点。
如果一个人不是完完全全做过某个项目,他是不太关心该项目的业务的,对其中的一些具体细节更是一窍不知,(如果我招你来做图书管理,你项目经历说你做过汽车调度,那我能问你汽车调度具体怎么回事吗?
不会,所以,你很容易蒙混过去的)而一个程序员的整个职业生涯中能实实在在和完完整整做出来的项目没几个,更别说在多个不同行业的项目了,有的程序员更是一辈子都只是在做某一个行业的项目,结果他就成了这个行业的专家(专门干一件事的家伙)。
所以,技术面试官通常没正好亲身经历过你简历写的那些项目,他不可能去问你写的那些项目的具体细节,而是只能泛泛地问你这个项目是多少人做的,做了多长时间,开发的过程,你在做项目的过程中有什么心得和收获,用的什么技术等面上的问题,所以,简历上的项目经历可以含有很多水分,很容易作假,技术面试官也无法在项目上甄别你的真伪。
简历该怎么写:
精通那些技术,有一些什么项目经历
教项目是为了巩固和灵活整合运用技术,增强学习的趣味性,熟悉做项目的流程,或得一些专业课程中无法获得的特有项目经验,增强自己面试的信心。
讲的项目应该真实可靠才有价值,否则,表面上是项目,实际上还是知识点的整合,对巩固技术点和增强学习的趣味性,但无法获得实际的项目经验。
(项目主要是增加你经验的可信度,获得更多面试机会,真正能不能找到工作,找到好工作,主要看你键盘上的功夫了)
学历一栏怎么着也不能写为高中,起码也要写个大专或以上,毕业院校编个二线城市的不知名的小学院,如果你不愿意去做假证,等到别人面试你时,再说“闲弃以前上的学校不好,因为对编程太感兴趣,就辍学了!
”
技术类面试、笔试题汇总
注:
标明*的问题属于选择性掌握的内容,能掌握更好,没掌握也没关系。
下面的参考解答只是帮助大家理解,不用背,面试题、笔试题千变万化,不要梦想着把题覆盖了,下面的题是供大家查漏补缺用的,真正的把这些题搞懂了,才能“以不变应万变”。
回答问题的时候能联系做过项目的例子是最好的,有的问题后面我已经补充联系到项目中的对应的案例了。
1、简述private、protected、public、internal修饰符的访问权限。
private:
私有成员,在类的内部才可以访问。
protected:
保护成员,该类内部和继承类中可以访问。
public:
公共成员,完全公开,没有访问限制。
internal:
当前程序集内可以访问。
2、ADO.NET中的五个主要对象
Connection:
主要是开启程序和数据库之间的连接。
没有利用连接对象将数据库打开,是无法从数据库中取得数据的。
Close和Dispose的区别,Close以后还可以Open,Dispose以后则不能再用。
Command:
主要可以用来对数据库发出一些指令,例如可以对数据库下达查询、新增、修改、删除数据等指令,以及调用存在数据库中的存储过程等。
这个对象是架构在Connection对象上,也就是Command对象是透过连接到数据源。
DataAdapter:
主要是在数据源以及DataSet之间执行数据传输的工作,它可以透过Command对象下达命令后,并将取得的数据放入DataSet对象中。
这个对象是架构在Command对象上,并提供了许多配合DataSet使用的功能。
DataSet:
这个对象可以视为一个暂存区(Cache),可以把从数据库中所查询到的数据保留起来,甚至可以将整个数据库显示出来,DataSet是放在内存中的。
DataSet的能力不只是可以储存多个Table而已,还可以透过DataAdapter对象取得一些例如主键等的数据表结构,并可以记录数据表间的关联。
DataSet对象可以说是ADO.NET中重量级的对象,这个对象架构在DataAdapter对象上,本身不具备和数据源沟通的能力;也就是说我们是将DataAdapter对象当做DataSet对象以及数据源间传输数据的桥梁。
DataSet包含若干DataTable、DataTableTable包含若干DataRow。
DataReader:
当我们只需要循序的读取数据而不需要其它操作时,可以使用DataReader对象。
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传值
5.Application传值
6.PreviosPage
Server.Transfer和Response.Redirect的区别:
Server.Transfer是服务器内部的转接,浏览器不知晓;Response.Redirect是有浏览器参与的,所以在地址栏中可以看到地址的变化。
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方法。
加分的补充回答:
回答设计模式中开发的SettingsProvider就是用的string类型的参数名做索引器参数。
7、属性和public字段的区别是什么?
调用set方法为一个属性设值,然后用get方法读取出来的值一定是set进去的值吗?
属性可以对设值、取值的过程进行非法值控制,比如年龄禁止设值负数,而字段则不能进行这样的设置。
虽然一般情况下get读取的值就是set设置的值,但是可以让get读取的值不是set设置的值的,极端的例子。
PublicAge{get{return100;}set{}}。
加分的补充回答:
用reflector反编译可以看出,属性内部本质上就是set_***、get_***方法,详细参考.net基础的部分。
classPerson
{
publicintAge
{
get
{
return3;
}
set
{
}
}
}
Personp1=newPerson();
p1.Age=30;
p1.Age++;
Console.Write(p1.Age);//输出3
8、三层架构
通常意义上的三层架构就是将整个业务应用划分为:
表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。
区分层次的目的即为了“高内聚,低耦合”的思想。
表现层(UI):
通俗讲就是展现给用户的界面,即用户在使用一个系统的时候的所见所得。
业务逻辑层(BLL):
针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理。
数据访问层(DAL):
该层所做事务直接操作数据库,针对数据的增添、删除、修改、更新、查找等每层之间是一种垂直的关系。
三层结构是N层结构的一种,一般来说,层次之间是向下依赖的,下层代码未确定其接口(契约)前,上层代码是无法开发的,下层代码接口(契约)的变化将使上层的代码一起变化。
优点:
分工明确,条理清晰,易于调试,而且具有可扩展性。
缺点:
增加成本。
9、MVC模式(*)
MVC(ModelViewController)模型-视图-控制器
aspx就是View,视图;Model:
DataSet、Reader、对象;Controller:
cs代码。
MVC是典型的平行关系,没有说谁在上谁在下的关系,模型负责业务领域的事情,视图负责显示的事情,控制器把数据读取出来填充模型后把模型交给视图去处理。
而各种验证什么的应该是在模型里处理了。
它强制性的使应用程序的输入、处理和输出分开。
MVC最大的好处是将逻辑和页面分离。
10、什么是装箱(boxing)和拆箱(unboxing)?
(*)
装箱:
从值类型接口转换到引用类型。
拆箱:
从引用类型转换到值类型。
objectobj=null;//引用类型
obj=1;//装箱,boxing。
把值类型包装为引用类型。
inti1=(int)obj;//拆箱。
unboxing
11、什么叫应用程序域(AppDomain)(*)
一种边界,它由公共语言运行库围绕同一应用程序范围内创建的对象建立(即,从应用程序入口点开始,沿着对象激活的序列的任何位置)。
应用程序域有助于将在一个应用程序中创建的对象与在其他应用程序中创建的对象隔离,以使运行时行为可以预知。
在一个单独的进程中可以存在多个应用程序域。
应用程序域可以理解为一种轻量级进程。
起到安全的作用。
占用资源小。
12、CTS、CLS、CLR分别作何解释(*)
CTS:
CommonTypeSystem通用系统类型。
Int32、Int16→int、String→string、Boolean→bool
CLS:
CommonLanguageSpecification通用语言规范。
不同语言语法的不同。
CLR:
CommonLanguageRuntime公共语言运行时,就是.Net提供的那些类。
13、在dotnet中类(class)与结构(struct)的异同?
Class可以被实例化,属于引用类型,是分配在内存的堆上的。
类是引用传递的。
Struct属于值类型,是分配在内存的栈上的。
结构体是复制传递的。
加分的回答:
Int32、Boolean等都属于结构体。
14、堆和栈的区别?
栈是编译期间就分配好的内存空间,因此你的代码中必须就栈的大小有明确的定义;局部值类型变量、值类型参数等都在栈内存中。
堆是程序运行期间动态分配的内存空间,你可以根据程序的运行情况确定要分配的堆内存的大小。
15、能用foreach遍历访问的对象的要求
需要实现IEnumerable接口或声明GetEnumerator方法的类型。
16、GC是什么?
为什么要有GC?
GC是垃圾收集器。
程序员不用担心内存管理,因为垃圾收集器会自动进行管理。
GC只能处理托管内存资源的释放,对于非托管资源则不能使用GC进行回收,必须由程序员手工回收,一个例子就是FileStream或者SqlConnection需要程序员调用Dispose进行资源的回收。
要请求垃圾收集,可以调用下面的方法:
GC.Collection()一般不需要手动调用GC.Collection()。
加分的回答:
有一次用OLEAutomation的方式操作Excel的时候,Excel经常不能正常退出,在MSDN网站上找到官方解答说要调用一下GC.Collection(),至于为什么这样就可以也没找到答案。
17、Strings=newString("xyz");创建了几个StringObject?
两个对象,一个是“xyx”,一个是指向“xyx”的引用对象。
18、值类型和引用类型的区别?
1.将一个值类型变量赋给另一个值类型变量时,将复制包含的值。
引用类型变量的赋值只复制对对象的引用,而不复制对象本身。
2.值类型不可能派生出新的类型:
所有的值类型均隐式派生自System.ValueType。
但与引用类型相同的是,结构也可以实现接口。
3.值类型不可能包含null值:
然而,可空类型功能允许将null赋给值类型。
4.每种值类型均有一个隐式的默认构造函数来初始化该类型的默认值。
19、C#中的接口和类有什么异同。
不同点:
不能直接实例化接口。
接口不包含方法的实现。
接口可以多继承,类只能单继承。
类定义可在不同的源文件之间进行拆分。
相同点:
接口、类和结构都可以从多个接口继承。
接口类似于抽象基类:
继承接口的任何非抽象类型都必须实现接口的所有成员。
接口和类都可以包含事件、索引器、方法和属性。
20、abstractclass和interface有什么区别?
相同点:
都不能被直接实例化,都可以通过继承实现其抽象方法。
不同点:
接口支持多继承;抽象类不能实现多继承。
接口只能定义行为;抽象类既可以定义行为,还可能提供实现。
接口可以用于支持回调(CallBack);抽象类不能实现回调,因为继承不支持。
接口只包含方法(Method)、属性(Property)、索引器(Index)、事件(Event)的签名,但不能定义字段和包含实现的方法;
抽象类可以定义字段、属性、包含有实现的方法。
接口可以作用于值类型(Struct)和引用类型(Class);抽象类只能作用于引用类型。
例如,Struct就可以继承接口,而不能继承类。
加分的补充回答:
讲设计模式的时候SettingsProvider的例子。
21、是否可以继承String类?
String类是sealed类故不可以继承。
22、try{}里有一个return语句,那么紧跟在这个try后的finally{}里的code会不会被执行,什么时候被执行?
会执行,在return前执行。
加分的补充回答(也助记):
读取数据库中数据的条数的程序
publicintQueryCount()
{
…..
try
{
returncmd.ExecuteScalar();
}
finally
{
cmd.Dispose();
}
}
如果C#设计的是先执行cmd.Dispose()再执行return就会出现return执行失败了,因为cmd已经Dispose了。
23、new关键字用法(*)
new运算符用于创建对象和调用构造函数。
new修饰符用于向基类成员隐藏继承成员。
new约束用于在泛型声明中约束可能用作类型参数的参数的类型。
24、如何把一个Array复制到ArrayList里(*)
实现1string[]s={"111","22222"};ArrayListlist=newArrayList();list.AddRange(s);
实现2string[]s={"111","22222"};ArrayListlist=newArrayList(s);
25、描述线程与进程的区别?
(*)
1.线程(Thread)与进程(Process)二者都定义了某种边界,不同的是进程定义的是应用程序与应用程序之间的边界,不同的进程之间不能共享代码和数据空间,而线程定义的是代码执行堆栈和执行上下文的边界。
2.一个进程可以包括若干个线程,同时创建多个线程来完成某项任务,便是多线程。
而同一进程中的不同线程共享代码和数据空间。
用一个比喻来说,如果一个家庭代表一个进程,在家庭内部,各个成员就是线程,家庭中的每个成员都有义务对家庭的财富进行积累,同时也有权利对家庭财富进行消费,当面对一个任务的时候,家庭也可以派出几个成员来协同完成,而家庭之外的人则没有办法直接消费不属于自己家庭的财产。
加分的回答:
举例,.Net培训中用多线程(ThreadPool)实现网站蜘蛛的案例。
26、什么是强类型,什么是弱类型?
哪种更好些?
为什么?
C#中
inti=3;
i="a";
不可以
JavaScript中
vari=3;
i="a";
可以
强类型是在编译的时候就确定类型的数据,在执行时类型不能更改,而弱类型在执行的时候才会确定类型。
没有好不好,二者各有好处,强类型安全,因为它事先已经确定好了,而且效率高。
弱类型更灵活,但是效率低,而且出错概率高
一般用于编译型编程语言,如c++,java,c#,pascal等,弱类型相比而言不安全,在运行的时候容易出现错误,但它灵活,多用于解释型编程语言,如javascript,vb等
27、什么是反射?
程序集包含模块,而模块又包括类型,类型下有成员,反射就是管理程序集,模块,类型的对象,它能够动态的创建类型的实例,设置现有对象的类型或者获取现有对象的类型,能调用类型的方法和访问类型的字段属性。
它是在运行时创建和使用类型实例
加分的补充回答:
聊用反射实现编辑器动态插件和如鹏网项目中插件体系实现第三方支付和定时任务的案例。
28、int、DateTime、string是否可以为null?
int、DateTime不能,因为其为Struct类型,而结构属于值类型,值类型不能为null,只有引用类型才能被赋值null。
string可以为null。
29、using关键字有什么用?
什么是IDisposable?
using可以声明namespace的引入,还可以实现非托管资源的释放,实现了IDisposiable的类在using中创建,using结束后会自动调用该对象的Dispose方法,释放资源。
加分的补充回答:
using其实等价于try……finally,用起来更方便。
int?
→Nullable
30、Assembly.Load("foo.dll");这句话是否正确?
(*)
错误,正确的应该是Assembly.Load("foo");或者Assembly.LoadFrom("foo.dll");
31、XML与HTML的主要区别
1.XML是区分大小写字母的,HTML不区分。
2.在HTML中,如果上下文清楚地显示出段落或者列表键在何处结尾,那么你可以省略
或者- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- ADotNet 面试 宝典