个人总结2019 ASP.NET面试题
1、什么是面向对象?
面向对象就是把一个人或事务的属性,比如名字,年龄这些定义在一个实体类里面。存和取的时候直接使用存取实体类就把这个人的名字,年龄这些全部存了,这个实体类就叫对象,这种思想就叫面向对象。
2、C# 的三大特性?
封装、继承、多态。
3、什么是继承?
就是子类实现父类的属性和方法,并在此基础上进行相关的扩展。
4、简述 private、 protected、 public、 internal 修饰符的访问权限。
private : 私有成员, 在类的内部才可以访问。
protected : 保护成员,该类内部和继承类中可以访问。
public : 公共成员,完全公开,没有访问限制。
internal: 当前程序集内可以访问。
5、a=10,b=15,请在不使用第三方变量的情况下,把a、b的值互换
int a=a+b; int b=a-b;int a=a-b;
6、session喜欢丢值且占内存,Cookis不安全,请问用什么办法代替这两种原始的方法
redis 或者 memcache。当然,微软也提供了解决方案。iis中由于有进程回收机制,系统繁忙的话Session会丢失,可以用Sate server或SQL Server数据库的方式。
7、try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后?
会执行,在return前执行。
8、XML 与 HTML 的主要区别
1. XML是区分大小写字母的,HTML不区分。
2. 在HTML中,如果上下文清楚地显示出段落或者列表键在何处结尾,那么你可以省略</p>或者</li>之类的结束 标记。在XML中,绝对不能省略掉结束标记。
3. 在XML中,拥有单个标记而没有匹配的结束标记的元素必须用一个 / 字符作为结尾。这样分析器就知道不用 查找结束标记了。
4. 在XML中,属性值必须分装在引号中。在HTML中,引号是可用可不用的。
5. 在HTML中,可以拥有不带值的属性名。在XML中,所有的属性都必须带有相应的值。
9、什么是DDD?什么是ATDD?什么是TDD?什么是BDD?
DDD:领域驱动开发(Domain Drive Design)
ATDD:验收测试驱动开发(Acceptance Test Driven Development)
TDD:测试驱动开发(Test-Driven Development)
BDD:行为驱动开发(Behavior Driven Development)
10.IOC容器?
1. IOC即控制反转,是一种设计思想,在之前的项目中,当我们需要一个对象时,需要new一个对象,而IOC的设计思想是我们将需要的对象注入到一个容器中,就会获得我们所需要的资源 。
2. IOC和DI IOC是控制反转,DI是依赖注入,控制反转的解释有些模棱两可,而依赖注入就很明确,我们将需要的对象注入到容器中,获取所需要的资源。
3. IOC控制反转:正常情况下程序开发是上端调用下端,依赖下端,依赖倒置原则告诉我们,上端不要依赖下端,要依赖抽象,上端只依赖抽象,细节交给第三方工厂(容器)来决定,这就是IOC,就是控制反转——使系统架构可以更稳定,支持扩展。
11、什么是切面?切面能实现什么?
1. AOP即面向切面编程,是OOP编程的有效补充。
2. 使用AOP技术,可以将一些系统性相关的编程工作,独立提取出来,独立实现,然后通过切面切入进系统。从而避免了在业务逻辑的代码中混入很多的系统相关的逻辑——比如权限管理,事物管理,日志记录等等。这些系统性的编程工作都可以独立编码实现,然后通过AOP技术切入进系统即可。从而达到了 将不同的关注点分离出来的效果。
12、什么是委托,事件是不是一种委托?
1. 委托可以把一个方法作为参数代入另一个方法。
2. 委托可以理解为指向一个函数的引用。
3. 事件是一种特殊的委托。
delegate <函数返回类型> <委托名> (<函数参数>)
13.c#多线程是什么?
多线程的优点:可以同时完成多个任务;可以使程序的响应速度更快;可以节省大量时间进行处理任务;可以随时停止任务;可以设置每个任务的优先级,以优化程序性能。
14.WebApi概述
Web API是在.NET Framework之上构建的Web的API的框架,Web API是一个编程接口,用于操作可通过标准HTTP方法和标头访问的系统,Web API需要基于.NET 3.5或更高版本才可以进行开发
15.什么是WebService
webservice是一种跨平台,跨语言的规范,用于不同平台,不同语言开发的应用之间的交互,是基于网络的、分布式的模块化组件,它执行特定的任务,遵守具体的技术规范。
16.存储过程是什么?有什么用?有什么优点?用什么来调用?
存储过程是预编译,安全性高,也是大大提高了效率,存储过程可以重复使用以减少数据库开发人员的工作量,复杂的逻辑我们可以使用存储过程完成,在存储过程中我们可以使用临时表,还可以定义变量,拼接sql语句,调用时,只需执行这个存储过程名,传入我们所需要的参数即可。
17.何为触发器?
触发器是一种特殊的存储过程,主要是通过事件触发而被执行。它可以强化约束来维护数据的完整性和一致性,可以跟踪数据库内的操作从而不允许未经许可的更新和变化。可以级联运算。
常见的触发器有三种:分别应用于Insert , Update , Delete 事件。
18.什么叫做泛型?
只是为了去掉重复代码,应对不同类型的共同需求。
19. C#中值类型和引用类型分别有哪些?
值类型:结构体(数值类型,bool型,用户定义的结构体),枚举,可空类型。
引用类型:数组,用户定义的类、接口、委托,object,字符串。
20.列举ASP.NET页面之间传递值的几种方式。
1. session(viewstate)简单,但易丢失
2. application 全局
3. cookie 简单,但可能不支持,可能被伪造
4. input type="hidden" 简单,可能被伪造
5. url参数简单,显示于地址栏,长度有限
6. 数据库稳定,安全,但性能相对弱
21 .NET的错误处理机制是什么?
.net错误处理机制采用try->catch->finally结构,发生错误时,层层上抛,直到找到匹配的Catch为止。
22.C#可否对内存进行直接的操作?
在.net下,.net引用了垃圾回收(GC)功能,它替代了程序员不过在C#中,不能直接实现Finalize方法,而是在析构函数中调用基类的Finalize()方法。
23. ADO.NET相对于ADO等主要有什么改进?
1:ado.net不依赖于ole db提供程序,而是使用.net托管提供的程序,
2:不使用com
3:不在支持动态游标和服务器端游
4:,可以断开connection而保留当前数据集可用
5:强类型转换
6:xml支持
24.如果在一个B/S结构的系统中需要传递变量值,但是又不能使用Session、Cookie、Application,您有几种方法进行处理?
this.Server.Transfer、Response.Redirect()、QueryString
25. .NET中读写数据库需要用到那些类?他们的作用?
Connection连接对象,Command执行命令和存储过程,DataReader向前只读的数据流,DataAdapter适配器,支持增删查询,DataSet数据级对象,相当与内存里的一张或多张表。
26.简要谈一下您对微软.NET架构下remoting和webservice两项技术的理解以及实际中的应用。
WS主要是可利用HTTP,穿透防火墙。而Remoting可以利用TCP/IP,二进制传送提高效率。
remoting是.net中用来跨越machine,process, appdomain进行方法调用的技术,对于三成结构的程序,就可以使用remoting技术来构建.它是分布应用的基础技术.相当于以前的DCOM。
Web Service是一种构建应用程序的普通模型,并能在所有支持internet网通讯的操作系统上实施。Web Service令基于组件的开发和web的结合达到最佳,基于组件的对象模型。
27.什么是反射?
动态获取程序集信息。
28.override与重载的区别?
重载是方法的名称相同。参数或参数类型不同,进行多次重载以适应不同的需要。
Override是子类对基类中函数的重写。为了适应需要。
29.装箱和拆箱的概念和原理
装箱是将值类型转化为引用类型的过程;
拆箱是将引用类型转化为值类型的过程
30.Session有什么重大BUG,微软提出了什么方法加以解决?
是iis中由于有进程回收机制,系统繁忙的话Session会丢失,可以用Sate server或SQL Server数据库的方式存储Session不过这种方式比较慢,而且无法捕获Session的END事件。
31.请编程实现一个冒泡排序算法?
int[] array = { 1, 3, 5, 7, 90, 2, 4, 6, 8, 10 }; int temp = 0; for (int i = 0; i < array.Length-1; i++) { for (int j = i+1; j < array.Length; j++) { if (array[j] < array[i]) { temp = array[i]; array[i] = array[j]; array[j] = temp; } } } Console.WriteLine($"冒泡排序"); for (int i = 0; i < array.Length; i++) { Console.WriteLine($"{array[i]}"); }
32.产生一个int数组,长度为100,并向其中随机插入1-100,并且不能重复?
List<int> list = new List<int>(); Random r = new Random(); while (true) { int temp2 = r.Next(1, 101); if (list.Count == 100) { break; } //不存在则添加 if (!list.Contains(temp2)) { list.Add(temp2); } } for (int i = 0; i < list.Count; i++) { Console.Write(list[i] + ","); }
33.查出学生总的分数
SELECT TOP (200) stu_name, SUM(fenshu) AS zong FROM student GROUP BY stu_name
34.SQL查询重复值
select * from xi a where (a.username) in (select username from xi group by username having count(*) > 1)
35、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录
delete from people where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1) and rowid not in (select min(rowid) from people group by peopleId having count(peopleId )>1)
36、查找表中多余的重复记录(多个字段)
select * from vitae a where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
37、删除表中多余的重复记录(多个字段),只留有rowid最小的记录
delete from vitae a where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1) and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
总结:
面试了10多家基本都有笔试,然后就是谈项目,做了哪些功能,遇到什么难题,怎么解决的,有什么收获,怎么优化,平时是否有关注技术热点等等。
最大的收获其实就是在面试的过程中所作的准备和思考,有些问题平常可能不容易发现的,但是面试官问了就知道自己缺在哪里了,然后下来查资料补补,多复习形成长期记忆,然后静等结果,调整心态;应当是有愈挫愈勇的心态,继续投简历,继续反思,继续学习。
注:
1、软件代码为原创,如需转载,请注明出处;
2、如果文中有什么错误,欢迎指出,谢谢!
博客地址:http://www.cnblogs.com/ouyang6994/
本文地址:https://www.cnblogs.com/ouyang6994/p/10952606.html
声明:本博客原创文字允许转载,转载时必须保留此段声明,且在文章页面明显位置给出原文链接。