C# 面试题及答案

2021-06-08 02:04

阅读:675

1 //第一种 
2 input id="tea_Name" name="tea.Name" type="text" value="马老师"/>
3 //第二种
4 @Html.TextBox("tea.Name",Model.tea.Name)
5 //第三种
6 @Html.TextBoxFor(m=>m.tea.Name)
7 //第四种
8 @Html.TextEditorFor(m=>m.tea.Name)

6.用一条SQL语句 查询出每门功课都大于80分的学生姓名,表结构如下

姓名   课程   分数  
张三 语文 81
张三 数学 75
张三 英语 82
李四 语文 76
李四 数学 90
李四 英语 82
王五 语文 81
王五 数学 100
王五 英语 92

 

 

 

 

 

 

 

 

答案一:select 姓名 from 表 where 姓名 not in (select 姓名 from 表 where 分数

答案二(推荐):select 姓名 from 表  group by 姓名 having min(分数)>80

7.简述Vue中methods、computed以及watch的用法及区别。

1#computed:计算属性将被混入到 Vue 实例中。所有 getter 和 setter 的 this 上下文自动地绑定为 Vue 实例。

2#methods:methods 将被混入到 Vue 实例中。可以直接通过 VM 实例访问这些方法,或者在指令表达式中使用。方法中的 this 自动绑定为 Vue 实例。

3#watch:是一种更通用的方式来观察和响应 Vue 实例上的数据变动。一个对象,键是需要观察的表达式,值是对应回调函数。值也可以是方法名,或者包含选项的对象。Vue 实例将会在实例化时调用 $watch(),遍历 watch 对象的每一个属性。
 官方API地址:https://cn.vuejs.org/v2/api/#computed

个人博客:https://blog.csdn.net/smartdt/article/details/75557369

8.现有一个业务系统有4万用户,所有用户每天产生6千万数据,系统要求快速查询60天数据,请给出你的实现方案。

9.描述你曾经或者正在使用的大型项目解决方案。

10.何时必须声明一个类为抽象类?

答案:当这个类中包含抽象方法时,或是该类并没有完全实现父类的抽象方法时。

11.MVC框架中,ActionResult,JsonResult,ContentResult哪个可以return view()?

答案:ActionResult。

12.Aspx页面中,updatepanel的作用是什么?

答案:UpdatePanel控制页面的局部更新。(局部更新控件)、

13.MVC框架中,当使用Get方法访问JsonResult时,能否直接采用以下写法:return json(obj).为什么?

答案:不能,要使用 res.JsonRequestBehavior = JsonRequestBehavior.AllowGet;//允许使用GET方式获取,否则用GET获取是会报错。 

14.可以采用foreach迭代的类的对象必须满足什么条件?

答案:需要实现IEnumerable接口或声明GetEnumerator方法的类型。注:不一定要实现IEnumerable接口,但一定要实现GetEnumrator方法。

15.在dotnet环境下,如何把数据库数据转换为XML格式输出?

将数据库的内容读取到dataTable或dataSet中,dataTable或dataSet转为xml。

private string ConvertDataTableToXML(DataTable xmlDS) //DataTable可改用dataset
    {
        MemoryStream stream = null;
        XmlTextWriter writer = null;
        try
        {
            stream = new MemoryStream();
            writer = new XmlTextWriter(stream, Encoding.Default);
            xmlDS.WriteXml(writer);
            int count = (int)stream.Length;
            byte[] arr = new byte[count];
            stream.Seek(0, SeekOrigin.Begin);
            stream.Read(arr, 0, count);
            UTF8Encoding utf = new UTF8Encoding();
            return utf.GetString(arr).Trim();
        }
        catch
        {
            return String.Empty;
        }
        finally
        {
            if (writer != null) writer.Close();
        }
    }

 

16.Html页面上,有如下代码.现在要求用户点击删除后,弹出删除确认的对话框,并在点击确定后弹出对话框“”“删除完毕”,用JS如何实现。

答案:

1 function Del()
2 {
3 if(confirm("确定删除"))
4       alert("删除成功")
5 }

17.请写出一个json的例子。

答案:[{"id":"123","name":"huawei"}]

18.List Alist 中有100个Domain1元素,且每个Domain1元素都有属性string  typStr,现在需要取出AList中所有typeStr="Atype"的元素,并组成新的List,该如何实现。

答案:

1 Liststring> BList=new Liststring>();
2 foreach(var a in AList)
3 {
4 if(a.typeStr=="Atype")
5     Blist.add(a.typeStr);
6 }

19.EF框架中,使用DBFirst时数据库中的表A没有主键,能否通过“从数据库更新模型“操作,将表A导入到EF框架中。

答案:不能,表必须要有主键,否则会报错。

savechange()方法返回0,而不是正常的大于0的书。切记设置主键。

返回错误InnerException = {"无法更新 EntitySet“t_Customer”,因为它有一个 DefiningQuery,而 元素中没有支持当前操作的 元素。"}。

在发现错误后要吧原有的数据库的表删除,重新更新。如果不删除的话,无法更新,并且要重新生成解决方案。
20.foreach和for循环谁的效率高?switch和if呢?

答案:foreach高,for 循环每次都要进行判断i的大小,foreach 依赖 IEnumerable.第一次 var a in GetList() 时 调用 GetEnumerator 返回第一个对象 并 赋给a,以后每次再执              行 var a in GetList() 的时候 调用 MoveNext.直到循环结束。期间GetList()方法只执行一次.

        同样的道理:当有多个判断时,switch更快。

21.WebService基于什么协议?

 答案:soap协议,而Soap建立在http上的。

22.WebService和WebAPI 有什么不同。   

1、webservice是基于SOAP协议的,数据格式是XML,webapi遵循的http协议,它的Response可以被而Web API的MediaTypeFormatter转换成Json、XML 或者任何你想转换的格式。
2、webservice它只能部署在IIS上,而webapi可以寄宿在不同的宿主上(寄宿的本质就是利用一个具体的应用程序为Web Api提供一个运行的环境,并解决请求的接收和响应的回复),如Web Host,Self Host方式
3、webservice 也可以通过ajax访问。

4、webapi无状态,相对webservice更轻量级。webapi支持如get,post等http操作,并且对限制带宽的设备,比如智能手机等支持的很好。

这样对比的话webservice貌似并不好用。但是我们为什么要用它呢,理由如下:

1、很好的跨编程语言和跨操作系统
2、可移植性:传统的WebService只是利用了HTTP通道,进行独立的交互,但是这个交互协议可以移植到其他协议下运作

 

23.C#是否支持多重继承?

答案:不支持。多重继承指的是一个类可以同时继承多个类,比如A类继承自B类和C类,这就是多重继承。C#只能继承一个类,但是可以继承多个接口。

24.修饰符protected internal 的意思?

internal修饰的b在同一个项目中哪里都可以访问,而在另外一个项目中就不能访问,说明“同一程序集”指的是同一个项目;对于protected internal修饰的a在同一项目中哪里都可以访问,而在其它项目中只有在派生类可以访问,所以protected internal 修饰的成员变量是同一程序集或者派生类可以访问,也就是protected跟internal的并集,而不是交集。(被protected internal修饰的属性/方法只能在它的在同一个程序集(Assembly)中的子类被访问)查资料找到了两种说法,不知道哪种是对的,个人以为是第一种是对的。

25.bs架构下,可否声明一个静态的数据库连接对象,所有的业务类都引用该静态连接对象去访问数据库?

答案:一个静态的Sqlconnection来管理项目内所有的数据库连接在绝大部分场景是不合理的
(没说绝对不可行,在winform单线程项目中,这样做是没有问题的,因为操作者是一个用户,每个用户都有一份程序副本)
如果是多个用户提交的请求是
同一个AppDomain中的函数,方法(这种说话不严谨,不过我暂时找不到更好的表达方式)
来处理时.都是用同一个静态的Sqlconnection对象是不行的.
会引起并发问题,会引起相互干扰.还需要加锁lock才能操作.

26.C#提供了一个默认的无参数构造函数,当我实现了另外一个有一个参数的构造函数的时候,还想保留这个无参数的构造函数。这样我应该写几个构造函数?

答案:两个。

27.能够阻止某一个类被其他类继承么?能够实现允许某个类被继承,但不允许其中某个方法被覆写吗?

答案:(1)当对一个类应用 sealed 修饰符时,此修饰符会阻止其他类从该类继承,(2)可以,标记这个类为public,并标记这个方法为sealed.

28.什么是强类型?C#是强类型吗,JS呢?

答案:强类型指的是程序中表达的任何对象所从属的类型都必须能在编译时刻确定。常见的强类型语言有C++、Java、Apex和Python等,C#是强类型,JS不是。

29.金额等精确的数值声明为什么类型?

答案:float,double,decimal

30.读写数据库都需要哪些对象,简要说明其作用。

答案1、 Connection:与数据源建立连接。
2、 Command:对数据源执行SQL命令并返回结果。
3、 DataReader:读取数据源的数据,只允许对将数据源以只读、顺向的方式查看其中所存储的数据。其常用于检索大量数据,DataReader对象还是一种非常节省资源的数据对象。
4、 DataAdapter:对数据源执行操作并返回结果,在DataSet与数据源之间建立通信,将数据源中的数据写入DataSet中,或根据DataSet中的数据绑定数据源。
5、 DataSet:内存中的数据库,是数据表的集合,它可以包含任意多个数据表。

31.通过程序控制GC的强制回收是否可以提高效率?

答案:个人以为是可以的(在网上没找到答案),GC是循环遍历所有资源的,如果你已经强制回收了,那么遍历的就会少,从而提高效率。

32.int?和int的区别。

答案:int?为可空类型,可以是null,他是通过把int装箱为引用类型实现的。

33.求数列(1,1,2,3,5,8,13。。。。)的和。

答案:见第三题的循环写法,定义一个变量为sum,sum+=arr[I]

34.BS架构下,在session中存储了一个datatable的对象y,y在什么时候会被GC回收?这种存储数据的方式是否合理?如果Application增加了对y的引用,什么时候会被GC回收?

答案:在session的生命周期结束之后回收,不合理,每个session储存在服务器端的内存里,每个用户都会有一个独立的session,如果session的内容过于复杂,当大量的用户访问的时候会导致内存溢出。Application是所有用户共有的,所以应该不会被回收(个人理解)

35.string和stringbuilder的区别。

答案:System.String是不可变的字符串。System.StringBuilder存放了一个可变的字符串,并提供一些对这个字符串修改的方法

36.举例写一个单例模式

 1 public class Singleton
 2     {
 3         private static Singleton _Singleton = null;
 4         private static object Singleton_Lock = new object();
 5         public static Singleton CreateInstance()
 6         {
 7             if (_Singleton == null) //双if +lock
 8             {
 9                 lock (Singleton_Lock)
10                 {
11                     Console.WriteLine("路过。");
12                     if (_Singleton == null)
13                     {
14                         Console.WriteLine("被创建。");
15                         _Singleton = new Singleton();
16                     }
17                 }
18             }
19             return _Singleton;
20         }
21     }

37.描述一下virtual、sealed、override和abstract的区别。

答案:

virtual申明虚方法的关键字,说明该方法可以被重写

sealed说明该类不可被继承

override重写基类的方法

abstract申明抽象类和抽象方法的关键字,抽象方法不提供实现,由子类实现,抽象类不可实例化。

38.List listNumber,其中存储了从1到100的数字,现需要将ListNumber按照形如“1,2,3,4.。。”输出,请写出相应的代码。

1 foreach(var a in listNumber.sort())
2 {
3   Console.WriteLine(a);
4 }

39.int,string,hashtable,datetime,datatable中哪些是引用类型?

答案:string,hashtable,datatable

40.


评论


亲,登录后才可以留言!