zoukankan      html  css  js  c++  java
  • 个人总结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
     声明:本博客原创文字允许转载,转载时必须保留此段声明,且在文章页面明显位置给出原文链接。
  • 相关阅读:
    清除微信浏览器缓存
    JS实现HTML标签转义及反转义
    mvc中服务器端、客户端属性验证
    Ajax.ActionLink参数详解
    Ajax.BeginForm参数详解
    AjaxHelper简介
    将博客搬至CSDN
    Sequelize小记
    端口: 查看端口状态
    搭建git服务器
  • 原文地址:https://www.cnblogs.com/ouyang6994/p/10952606.html
Copyright © 2011-2022 走看看