.net程序员面试小结(内附一些面试题和答案)
2018-06-22 07:57:23来源:未知 阅读 ()
今天下午去面试,面试官和HR小姐姐都很好,没有做面试题,用聊天的方式来交流技术,整个过程很轻松,从中也学到了很多知识。
下面就来总结一下面试过程。
一、深刻了解自己的简历
无论是HR还是技术面试人,首先都从简历里面了解你,我的这个面试题都是围绕着我的简历中提到的技术来开展的,令我不好意思的是有好多问题我并不能给出很好的深层次的答案。
二、生活业余时间也要扩展自己
平时多关注技术类新闻,多写博客注意积累,这个也有问到哦。
三、问题总结
1、三层架构是哪三层?各自干什么?三层架构有什么优缺点?(链接:http://blog.163.com/jlkjwjh_changfeng/blog/static/3633782620108269504961/)
三层指
表现层(UI):用户看到的界面
业务逻辑层(BLL):对数据层的操作,对数据业务逻辑的处理。
数据访问层(DAL):直接操作数据库,对数据进行查找、增添、修改、删除等操作。
优点:
1)、开发人员可以只专注于整个结构中的某一层
2)、可以很容易用新的实现来替换原有层次的实现
3)、安全性高
4)、降低层与层之间的依赖,高内聚,低耦合
(内聚:一个模块内各个元素彼此结合的紧密程度;耦合:一个软件结构内不同模块之间互连程度的度量)
5)、有利于标准化
6)、利于各层逻辑的复用。
7)、扩展性强
8)、项目结构更清楚,分工更明确,有利于后期的升级和维护
缺点:
1)、降低了系统的性能,比如操作数据库需要中间层,而不是直连
2)、有可能会导致级联的修改,比如新加一个模块,需要三个层都新加。
3)、增加了成本,增加了代码量
=================================================================================
2、EF(entityFramework)和ADO.NET的对比(链接:http://blog.csdn.net/wangzl1163/article/details/72897170)
1)、使用EF开发只需要操作对象,使开发更对象化,抛弃了数据库为中心的思想,完全的面向对象的思想。ADO.NET以数据库为中心来开发数据访问层。
2)、采用EF减少了数据处理工作,可以简化开发,达到快速开发的目的。采用ADO.NET开发需要编写sql语句,并处理数据与对象的转换,开发效率低。
3)、EF消耗内存较大,ADO.NET消耗内存较小。EF的性能不如ADO.NET。
4)、EF处理数据库的方式是针对单个对象的,对数据库的增删改都是对一条记录而言。ADO.NET既适合逐条语句处理数据也适合批量删除、修改数据。
5)、EF不适合数据库中有大量存储过程、触发器的开关,此时ADO.NET适合。
6)、EF适用于表与表关系比较明确的环境中。如本应有外键关系,但又没建外键的,这是适用EF会增加工作量。ADO.NET对此没有要求。
===================================================================================
3、UEditor(百度富文本编辑器)和KindEditor的区别(链接:https://www.zzidc.com/info/biancheng/2508.html和http://blog.csdn.net/u013987661/article/details/54378005)
1)、Ke(KindEditor)要比Ue(UEditor)小
2)、Ke和Ue的容器不同,一个是textarea标签,一个是script标签,如果是ke的textarea标签的话,表单的参数名可以通过name指定,而ue提交表单的默认参数名是editorValue,可以通过创建对象的时候传入textarea参数解决。
KindEditor:
<textarea name="content"></textarea>
UEditor:
<script type="text/javascript"> var ue = UE.getEditor('editor',{toolbars: [ ['fullscreen', 'source', 'undo', 'redo'], ['bold', 'italic'] ],textarea:"content"}); </script>
====================================================================================
4、重载(overload)和重写(override)的区别(链接:https://www.cnblogs.com/lonelyDog/archive/2011/11/16/2251011.html)
overload是重载,一般是用于在一个类内实现若干重载的方法,这些方法的名称相同而参数形式不同。
重载的规则:
1、在使用重载时只能通过相同的方法名、不同的参数形式实现。不同的参数类型可以是不同的参数类型,不同的参数个数,不同的参数顺序(参数类型必须不一样);
2、不能通过访问权限、返回类型、抛出的异常进行重载;
3、方法的异常类型和数目不会对重载造成影响;
override是重写(覆盖)了一个方法,以实现不同的功能。一般是用于子类在继承父类时,重写(重新实现)父类中的方法。
重写(覆盖)的规则:
1、重写方法的参数列表必须完全与被重写的方法的相同,否则不能称其为重写而是重载.
2、重写方法的访问修饰符一定要大于被重写方法的访问修饰符(public>protected>default>private)。
3、重写的方法的返回值必须和被重写的方法的返回一致;
4、重写的方法所抛出的异常必须和被重写方法的所抛出的异常一致,或者是其子类;
5、被重写的方法不能为private,否则在其子类中只是新定义了一个方法,并没s有对其进行重写。
6、静态方法不能被重写为非静态的方法(会编译出错)。
===================================================================================
5、对委托和事件怎么理解(链接:http://www.tracefact.net/tech/009.html)
委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递,这种将方法动态地赋给参数的做法,可以避免在程序中大量使用If-Else(Switch)语句,同时使得程序具有更好的可扩展性。使用委托可以将多个方法绑定到同一个委托变量,当调用此变量时(这里用“调用”这个词,是因为此变量代表一个方法),可以依次调用所有绑定的方法。
事件是一种特殊的委托的实例,或者说是受限制的委托,是委托一种特殊应用,在类的外部只能施加+=,-=操作符。
===================================================================================
6、快速开发的工具有哪些?(这个我没有接触过T_T,希望有用过的能够告知一下,谢谢)
===================================================================================
7、sqlite和MS Sql server有什么不同
sqlite 是文件型数据库,是轻量级数据库,对小数据量的数据存储方便。
sqlserver是关系型数据库,是大型数据库,常用于企业级应用的后台数据存储。
语法的不同参考链接:http://blog.csdn.net/xsl1990/article/details/16851593
====================================================================================
好啦,就先总结这么多吧,以后慢慢再添,其实还有设计模式还有前端的一些问题没有写。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- asp.net源程序编译为dll文件并调用的实现过程 2020-03-29
- Asp.net MVC SignalR来做实时Web聊天实例代码 2020-03-29
- ASP.NET MVC中jQuery与angularjs混合应用传参并绑定数据 2020-03-29
- Asp.Net中WebForm的生命周期 2020-03-29
- ASP.NET使用Ajax返回Json对象的方法 2020-03-23
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash