• 个人总结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
     声明:本博客原创文字允许转载,转载时必须保留此段声明,且在文章页面明显位置给出原文链接。
  • 相关阅读:
    moss jscript
    CSS两端对准
    简单的日期格式验证
    .NET中使用Exchange 2007 Webservice来读取邮件
    张二狗
    spcontext
    Infopath表单用改控件值提交或作别的更改时一定要在控件属性浏览器表单的回发设置为始终.
    使用 Web 服务
    SharePoint 2010中开发模式的改进 COM 客户端对象模型
    Retrieve data from Separate Oracle System
  • 原文地址:https://www.cnblogs.com/ouyang6994/p/10952606.html
Copyright © 2020-2023  润新知