.net经典面试题

一、简述 private、 protected、 public、 internal 修饰符的访问权限。html

private : 私有成员, 在类的内部才能够访问。protected : 保护成员,该类内部和继承类中能够访问。jquery

public : 公共成员,彻底公开,没有访问限制。 internal: 当前程序集内能够访问。程序员

二、ADO.NET中的五个主要对象web

Connection:主要是开启程序和数据库之间的链接。没有利用链接对象将数据库打开,是没法从数据库中取得数据的。Close和Dispose的区别,Close之后还能够Open,Dispose之后则不能再用。面试

Command:主要能够用来对数据库发出一些指令,例如能够对数据库下达查询、新增、修改、删除数据等指令,以及调用存在数据库中的存储过程等。这个对象是架构在Connection 对象上,也就是Command 对象是透过链接到数据源。ajax

DataAdapter:主要是在数据源以及DataSet 之间执行数据传输的工做,它能够透过Command 对象下达命令后,并将取得的数据放入DataSet 对象中。这个对象是架构在Command对象上,并提供了许多配合DataSet 使用的功能。算法

DataSet:这个对象能够视为一个暂存区(Cache),能够把从数据库中所查询到的数据保留起来,甚至能够将整个数据库显示出来,DataSet是放在内存中的。DataSet 的能力不仅是能够储存多个Table 而已,还能够透过DataAdapter对象取得一些例如主键等的数据表结构,并能够记录数据表间的关联。DataSet 对象能够说是ADO.NET 中重量级的对象,这个对象架构在DataAdapter对象上,自己不具有和数据源沟通的能力;也就是说咱们是将DataAdapter对象当作DataSet 对象以及数据源间传输数据的桥梁。DataSet包含若干DataTable、DataTableTable包含若干DataRow。sql

DataReader:当咱们只须要循序的读取数据而不须要其它操做时,可使用DataReader 对象。DataReader对象只是一次一笔向下循序的读取数据源中的数据,这些数据是存在数据库服务器中的,而不是一次性加载到程序的内存中的,只能(经过游标)读取当前行的数据,并且这些数据是只读的,并不容许做其它的操做。由于DataReader 在读取数据的时候限制了每次只读取一笔,并且只能只读,因此使用起来不但节省资源并且效率很好。使用DataReader 对象除了效率较好以外,由于不用把数据所有传回,故能够下降网络的负载。数据库

ADO.NET 使用Connection 对象来链接数据库,使用Command 或DataAdapter对象来执行SQL语句,并将执行的结果返回给DataReader 或 DataAdapter ,而后再使用取得的DataReader 或DataAdapter 对象操做数据结果。编程

三、列举ASP.NET 页面之间传递值的几种方式。

1.使用QueryString, 如....?id=1; response. Redirect().... 2.使用Session变量 3.使用Server.Transfer4.Cookie传值

四、C#中的委托是什么?事件是否是一种委托?事件和委托的关系。

委托能够把一个方法做为参数代入另外一个方法。委托能够理解为指向一个函数的指针。

委托和事件没有可比性,由于委托是类型,事件是对象,下面说的是委托的对象(用委托方式实现的事件)和(标准的event方式实现)事件的区别。事件的内部是用委托实现的。由于对于事件来说,外部只能“注册本身+=、注销本身-=”,外界不能够注销其余的注册者,外界不能够主动触发事件,所以若是用Delegate就无法进行上面的控制,所以诞生了事件这种语法。事件是用来阉割委托实例的,类比用一个自定义类阉割List。事件只能add、remove本身,不能赋值。事件只能+=、-=,不能= 。加分的补充回答:事件内部就是一个private的委托和add、remove两个方法

 

面试聊:用Reflector查看.Net的类的内部实现,解决问题。

五、override与重载(overload)的区别

重载是方法的名称相同。参数或参数类型不一样,进行屡次重载以适应不一样的须要。重载(overload)是面向过程的概念。

Override 是进行基类中函数的重写。Override是面向对象的概念

六、C#中索引器是否只能根据数字进行索引?是否容许多个索引器参数?

参数的个数和类型都是任意的。加分的补充回答:用reflector反编译能够看出,索引器的内部本质上就是set_item、get_item方法。

索引的语法:public string this[string s],经过get、set块来定义取值、赋值的逻辑

索引能够有多个参数、参数类型任意

索引能够重载。

若是只有get没有set就是只读的索引。索引其实就是set_Item、get_Item两个方法。

七、属性和public字段的区别是什么?调用set方法为一个属性设值,而后用get方法读取出来的值必定是set进去的值吗?

属性能够对设值、取值的过程进行非法值控制,好比年龄禁止设值负数,而字段则不能进行这样的设置。虽然通常状况下get读取的值就是set设置的值,可是可让get读取的值不是set设置的值的,极端的例子。Public Age{get{return 100;}set{}}。加分的补充回答:用reflector反编译能够看出,属性内部本质上就是set_***、get_***方法    class Person

{        public int Age

{            get            {                return 3;            }            set            {            }

}    }

Person p1 = new Person();            p1.Age = 30;            p1.Age++;            Console.Write(p1.Age);//输出3

必须手写掌握的代码(既包含拿电脑写,拿笔写):

一、 手写三层架构

二、 手写冒泡排序

三、 手写AJAX:XMLHttpRequest

四、 手写增删改查、SQLHelper

八、三层架构

一般意义上的三层架构就是将整个业务应用划分为:表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。区分层次的目的即为了“高内聚,低耦合”的思想。表现层(UI):通俗讲就是展示给用户的界面,即用户在使用一个系统的时候的所见所得。业务逻辑层(BLL):针对具体问题的操做,也能够说是对数据层的操做,对数据业务逻辑处理。数据访问层(DAL):该层所作事务直接操做数据库,针对数据的增添、删除、修改、更新、查找等每层之间是一种垂直的关系。三层结构是N层结构的一种,通常来讲,层次之间是向下依赖的,下层代码未肯定其接口(契约)前,上层代码是没法开发的,下层代码接口(契约)的变化将使上层的代码一块儿变化。

优势: 分工明确,条理清晰,易于调试,并且具备可扩展性。

缺点: 增长成本。

九、什么是装箱(boxing)和拆箱(unboxing)? (*)

Object是引用类型,可是它的子类Int32居然不能去Object能去的“要求必须是引用类型”的地方,违反了继承的原则,因此须要把Int32装在Object中才能传递。

装箱:从值类型接口转换到引用类型。

拆箱:从引用类型转换到值类型。

object obj = null;//引用类型

obj = 1;//装箱,boxing。把值类型包装为引用类型。

int i1 = (int)obj;//拆箱。unboxing

2)下面三句代码有没有错,以inboxing或者unboxing为例,解释一下内存是怎么变化的

int i=10; object obj = i;int j = obj;

分析:在inboxing(装箱)时是不须要显式的类型转换的,不过unboxing(拆箱)须要显式的类型转换,因此第三行代码应该改成:

3 int j = (int)obj;

要掌握装箱与拆箱,就必须了解CTS及它的特色:NET重要技术和基础之一的CTS(Common Type System)。CTS是为了实如今应用程序声明和使用这些类型时必须遵循的规则而存在的通用类型系统。.Net将整个系统的类型分红两大类 :值类型和引用类型。

CTS中的全部东西都是对象;全部的对象都源自一个基类——System.Object类型。值类型的一个最大的特色是它们不能为null,值类型的变量总有一个值。为了解决值类型不能够为null,引用类型能够为null的问题,微软在.Net中引入了装箱和拆箱:装箱就是将值类型用引用类型包装起来转换为引用类型;而从引用类型中拿到被包装的值类型数据进行拆箱。

十、CTS、CLS、CLR分别做何解释(*)把英文全称背过来。

C#和.Net的关系。

C#只是抽象的语言,能够把C#编译生成Java平台的二进制代码,也能够把Java代码编译生成.Net平台的二进制代码。因此C#只是提供了if、while、+-*/、定义类、int、string等基础的语法,而Convert.ToInt3二、FileStream、SqlConnection、String.Split等都属于.Net的东西。深蓝色是C#的,浅蓝色是.Net的。

C# new→IL:newobj

C# string →.Net中的String

类型的差异:.net中的Int32在C#中是int,在VB.Net中是Integer。String、Int32等公共类型。

语法的差异:IL中建立一个对象的方法是L_0001: newobj instance void 索引.C1::.ctor()

C#中是new C1();VB.net中是 Dim c1 As New C1

CTS:Common Type System 通用类型系统。Int3二、Int16→int、String→string、Boolean→bool。每种语言都定义了本身的类型,.Net经过CTS提供了公共的类型,而后翻译生成对应的.Net类型。

CLS:Common Language Specification 通用语言规范。不一样语言语法的不一样。每种语言都有本身的语法,.Net经过CLS提供了公共的语法,而后不一样语言翻译生成对应的.Net语法。

CLR:Common Language Runtime 公共语言运行时,就是GC、JIT等这些。有不一样的CLR,好比服务器CLR、Linux CLR(Mono)、Silverlight CLR(CoreCLR)。至关于一个发动机,负责执行IL。

十一、在dotnet中类(class)与结构(struct)的异同?

Class能够被实例化,属于引用类型,是分配在内存的堆上的。类是引用传递的。

Struct属于值类型,是分配在内存的栈上的。结构体是复制传递的。加分的回答:Int3二、Boolean等都属于结构体

十二、堆和栈的区别?

栈是编译期间就分配好的内存空间,所以你的代码中必须就栈的大小有明确的定义;局部值类型变量、值类型参数等都在栈内存中。

堆是程序运行期间动态分配的内存空间,你能够根据程序的运行状况肯定要分配的堆内存的大小。

1三、能用foreach遍历访问的对象的要求

须要实现IEnumerable接口或声明GetEnumerator方法的类型。

1四、GC是什么? 为何要有GC?

C/C++中由程序员进行对象的回收像学校食堂中由学生收盘子,.Net中由GC进行垃圾回收像餐馆中店员去回收。

GC是垃圾收集器(Garbage Collection)。程序员不用担忧内存管理,由于垃圾收集器会自动进行管理。GC只能处理托管内存资源的释放,对于非托管资源则不能使用GC进行回收,必须由程序员手工回收,一个例子就是FileStream或者SqlConnection须要程序员调用Dispose进行资源的回收。

要请求垃圾收集,能够调用下面的方法:GC.Collect()通常不须要手动调用GC.Collect()。当一个对象没有任何变量指向(再也不能使用)的时候就能够被回收了。

基础知识:当没有任何变量指向一个对象的时候对象就能够被回收掉了,但不必定会当即被回收。

object obj = new object();//只有new才会有新对象

Console.WriteLine(obj);

object obj2 = obj;

obj = null;

obj2 = null;

Console.WriteLine();

1五、值类型和引用类型的区别?

1.将一个值类型变量赋给另外一个值类型变量时,将复制包含的值。引用类型变量的赋值只复制对对象的引用,而不复制对象自己。

2.值类型不可能派生出新的类型:全部的值类型均隐式派生自 System.ValueType。但与引用类型相同的是,结构也能够实现接口。

3.值类型不可能包含 null 值:然而,可空类型功能容许将 null 赋给值类型。

4.每种值类型均有一个隐式的默认构造函数来初始化该类型的默认值。

1六、C#中的接口和类有什么异同。

不一样点:

不能直接实例化接口。

接口不包含方法的实现。

接口能够多继承,类只能单继承。

类定义可在不一样的源文件之间进行拆分。

相同点:

接口、类和结构均可以从多个接口继承。

接口相似于抽象基类:继承接口的任何非抽象类型都必须实现接口的全部成员。

接口和类均可以包含事件、索引器、方法和属性。

基础知识:接口只能定义方法(只能定义行为,不能定义实现也就是字段),由于事件、索引器、属性本质上都是方法,因此接口中也能够定义事件、索引器、属性。

1七、abstract class和interface有什么区别?

相同点:

都不能被直接实例化,均可以经过继承实现其抽象方法。

不一样点:

接口支持多继承;抽象类不能实现多继承。

接口只能定义行为;抽象类既能够定义行为,还可能提供实现。

接口只包含方法(Method)、属性(Property)、索引器(Index)、事件(Event)的签名,但不能定义字段和包含实现的方法;

抽象类能够定义字段、属性、包含有实现的方法。

接口能够做用于值类型(Struct)和引用类型(Class);抽象类只能做用于引用类型。例如,Struct就能够继承接口,而不能继承类。

加分的补充回答:讲设计模式的时候SettingsProvider的例子。

1八、是否能够继承String类?

String类是sealed类故不能够继承。

1九、int、DateTime、string是否能够为null?

null表示“不知道”,而不是“没有”。没有年龄和不知道年龄是不同。

数据库中null不能用0表示。0岁和不知道多少岁不同。

Sex is zero。《色便是空》

//int i1 = null;

//int? i2 = null;//值类型后加?就成了可空数据类型

////int i3 = i2;//因此把可空的赋值给必定不能为空的会报错。

//int i4 = (int)i2;//能够显式转换,由程序员来保证“必定不为空”

//int? i5 = i4;//必定会成功!

//using()→try{]catch{}finally{}

//int?是微软的一个语法糖。是一种和int没有直接关系的Nullable类型

Nullable<int> d1 = new Nullable<int>();//int? d1=null;

Nullable<int> d2 = new Nullable<int>(3);//int? d2=3;

Console.WriteLine(d1==null);

int、DateTime不能,由于其为Struct类型,而结构属于值类型,值类型不能为null,只有引用类型才能被赋值null。string能够为null。

C#中int等值类型不能够为null、而数据库中的int能够为null,这就是纠结的地方。int?就变成了可空的int类型。bool?、DateTime?

int i1 = 3;

int? i2 = i1;

//int i3 = i2;//不能把可能为空的赋值给必定不能为空的变量

int i3 = (int)i2;//显式转换

可空数据类型经典应用场景:三层中的Model属性的设计。

int?翻译生成.Net的Nullable<int>,CTS。

20、using关键字有什么用?什么是IDisposable?

using能够声明namespace的引入,还能够实现非托管资源的释放,实现了IDisposiable的类在using中建立,using结束后会自动调用该对象的Dispose方法,释放资源。加分的补充回答:using其实等价于try……finally,用起来更方便。

2一、XML 与 HTML 的主要区别

1. XML是区分大小写字母的,HTML不区分。

2. 在HTML中,若是上下文清楚地显示出段落或者列表键在何处结尾,那么你能够省略</p>或者</li>之类的结束 标记。在XML中,绝对不能省略掉结束标记。

HTML:<img src="1.jpg"><br><br>

XML:<img src="1.jpg"></img><br/><br/>

3. 在XML中,拥有单个标记而没有匹配的结束标记的元素必须用一个 / 字符做为结尾。这样分析器就知道不用 查找结束标记了。

4. 在XML中,属性值必须分装在引号中。在HTML中,引号是可用可不用的。

5. 在HTML中,能够拥有不带值的属性名。在XML中,全部的属性都必须带有相应的值。

XML是用来存储和传输数据的

HTML是用来显示数据的

若是使用了彻底符合XML语法要求的HTML,那么就叫作符合XHTML标准。符合XHTML标准的页面有利于SEO。

2二、string str = null 与 string str =””说明其中的区别。

答:string str = null 是不给他分配内存空间,而string str = \"\" 给它分配长度为空字符串的内存空间。 string str = null没有string对象,string str = “”有一个字符串对象。

string s3 = string.Empty;//反编译发现,string.Empty就是在类构造函数中 Empty = "";

2三、写出一条Sql语句:取出表A中第31到第40记录(SQLServer,以自动增加的ID做为主键,注意:ID可能不是连续的。

答:解1: select top 10 * from A where id not in (select top 30 id from A)

演变步骤:

1)select top 30 id from T_FilterWords--取前条

2)select * from T_FilterWords

where id not in (select top 30 id from T_FilterWords)--取id不等于前三十条的

--也就是把前条排除在外

3)select top 10 * from T_FilterWords

where id not in (select top 30 id from T_FilterWords)

--取把前条排除在外的前条,也就是-40条

2: select top 10 * from A where id > (select max(id) from (select top 30 id from A )as A)

解答3:用ROW_NUMBER实现

2四、.Net中全部可序列化的类都被标记为

[serializable]

2五、什么是code-Behind技术。

就是代码隐藏,在ASP.NET中经过ASPX页面指向CS文件的方法实现显示逻辑和处理逻辑的分离,这样有助于web应用程序的建立。好比分工,美工和编程的能够个干各的,不用再像之前asp那样都代码和html代码混在一块儿,难以维护。code-Behind是基于部分类技术实现的,在个人项目的三层代码生成器中用到了部分类。

2六、接口是一种引用类型,在接口中能够声明(   a),但不能够声明公有的域或私有的成员变量。   
  a) 方法、属性、索引器和事件;    b) 索引器和字段;       c) 事件和字段;

解读:接口中不能声明字段只能声明方法,属性、索引器和事件 最终都编译生成方法。由于字段属于实现层面的东西,只有存取值的时候才会用到字段,因此中接口中不能定义字段。

2七、ADO.NET中,对于Command对象的ExecuteNonQuery()方法和ExecuteReader()方法,下面叙述错误的是(c)。  
  a) insert、update、delete等操做的Sql语句主要用ExecuteNonQuery()方法来执行;  
  b) ExecuteNonQuery()方法返回执行Sql语句所影响的行数。  
  c) Select操做的Sql语句只能由ExecuteReader()方法来执行;  
  d) ExecuteReader()方法返回一个DataReader对象;

SQLHelper实现一下。

2八、StringBuilder 和 String 的区别?

答:String 在进行运算时(如赋值、拼接等)会产生一个新的实例,而 StringBuilder 则不会。因此在大量字符串拼接或频繁对某一字符串进行操做时最好使用 StringBuilder,不要使用 String

若是要操做一个不断增加的字符串,尽可能不用String类,改用StringBuilder类。两个类的工做原理不一样:String类是一种传统的修改字符串的方式,它确实能够完成把一个字符串添加到另外一个字符串上的工做没错,可是在.NET框架下,这个操做实在是划不来。由于系统先是把两个字符串写入内存,接着删除原来的String对象,而后建立一个String对象,并读取内存中的数据赋给该对象。这一来二去的,耗了很多时间。而使用System.Text命名空间下面的StringBuilder类就不是这样了,它提供的Append方法,可以在已有对象的原地进行字符串的修改,简单并且直接。固然,通常状况下觉察不到这两者效率的差别,但若是你要对某个字符串进行大量的添加操做,那么StringBuilder类所耗费的时间和String类简直不是一个数量级的。

2九、请叙述属性与索引器的区别。 *)

属性 索引器

经过名称标识。 经过签名标识。

经过简单名称或成员访问来访问。 经过元素访问来访问。

能够为静态成员或实例成员。 必须为实例成员。

属性的   get   访问器没有参数。 索引器的   get   访问器具备与索引器相同的形参表。

属性的   set   访问器包含隐式   value   参数。 除了   value   参数外,索引器的 set 访问器还具备与索引器相同的形参表。

30、请解释ASP。NET中的web页面与其隐藏类之间的关系?

一个ASP.NET页面通常都对应一个隐藏类,通常都在ASP.NET页面的声明中指定了隐藏类例如一个页面Tst1.aspx的页面声明以下

<%@ Page language="c#" Codebehind="Tst1.aspx.cs" AutoEventWireup="false" Inherits="T1.Tst1" %>

Codebehind="Tst1.aspx.cs" 代表经编译此页面时使用哪个代码文件

Inherits="T1.Tst1" 表用运行时使用哪个隐藏类

aspx页面会编译生成一个类,这个类从隐藏类继承。

3一、您在什么状况下会用到虚方法?它与接口有什么不一样?

答案:子类从新定义父类的某一个方法时,必须把父类的方法定义为virtual

在定义接口中不能有方法体,虚方法能够。

实现时,子类能够不从新定义虚方法,但若是一个类继承接口,那必须实现这个接口。

3二、DataReader和DataSet的异同?

DataReader使用时始终占用SqlConnection,在线操做数据库

每次只在内存中加载一条数据,因此占用的内存是很小的

是只进的、 只读的

DataSet则是将数据一次性加载在内存中.抛弃数据库链接..读取完毕即放弃数据库链接(非链接模式)

DataSet将数据所有加载在内存中.因此比较消耗内存...可是确比DataReader要灵活..能够动态的添加行,列,数据.对数据库进行 回传更新操做(动态操做读入到内存的数据)

3三、public static const int  A = 1;这段代码有错误么?

错误:const不能被修饰为static ;由于定义为常量 (const )后就是静态的(static )。

3四、传入某个属性的set方法的隐含参数的名称是什么?

value,它的类型和属性所声名的类型相同。

3五、C#支持多重继承么?

类之间不支持,接口之间支持。类对接口叫作实现,不叫继承。 类是爹、接口是能力,能有多个能力,但不能有多个爹。

3六、C#中全部对象共同的基类是什么?System.Object

3七、经过超连接怎样传递中文参数?

答:用URL编码,经过QueryString传递,用urlencode编码 用urldecode解码

3八、string、String;int、Int32;Boolean、bool的区别

String、Int3二、Boolean等都属于.Net中定义的类,而string、int、bool至关于C#中对这些类定义的别名。CTS。

3九、Server.TransferResponse.Redirect的区别是什么?(常考)

: Server.Transfer仅是服务器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;Response.Redirect则是彻底的跳转,浏览器将会获得跳转的地址,并从新发送请求连接。这样,从浏览器的地址栏中能够看到跳转后的连接地址。

Server.Transfer是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,而后把这些内容再发给浏览器,浏览器根本不知道服务器发送的内容是从哪儿来的,因此它的地址栏中仍是原来的地址。 这个过程当中浏览器和Web服务器之间通过了一次交互。

Response.Redirect就是服务端根据逻辑,发送一个状态码,告诉浏览器从新去请求那个地址,通常来讲浏览器会用刚才请求的全部参数从新请求。这个过程当中浏览器和Web服务器之间通过了两次交互。

Server.Transfer不能够转向外部网站,而Response.Redirect能够。

Server.Execute效果和Server.Transfer相似,可是是把执行的结果嵌入当前页面。

40、不是说字符串是不可变的吗?string s="abc";s="123"不就是变了吗?

String是不可变的在这段代码中,s原先指向一个String对象,内容是 "abc",而后咱们将s指向"123",那么s所指向的那个对象是否发生了改变呢?答案是没有。这时,s不指向原来那个对象了,而指向了另外一个 String对象,内容为"123",原来那个对象还存在于内存之中,只是s这个引用变量再也不指向它了。

4一、是否能够从一个static方法内部发出对非static方法的调用?

不能够。由于非static方法是要与对象关联在一块儿的,必须建立一个对象后,才能够在该对象上进行方法调用,而static方法调用时不须要建立对象,能够直接调用。也就是说,当一个static方法被调用时,可能尚未建立任何实例对象,若是从一个static方法中发出对非static方法的调用,那个非static方法是关联到哪一个对象上的呢?这个逻辑没法成立,因此,一个static方法内部不能发出对非static方法的调用。

4二、说出一些经常使用的类、接口,请各举5个

要让人家感受你对.Net开发很熟,因此,不能仅仅只列谁都能想到的那些东西,要多列你在作项目中涉及的那些东西。就写你最近写的那些程序中涉及的那些类。

经常使用的类:StreamReader、WebClient、Dictionary<K,V>、StringBuilder、SqlConnection、FileStream、File、Regex、List<T>

经常使用的接口:IDisposable、IEnumerable、IDbConnection、IComparable、ICollectionIList、IDictionary

要出乎意料!不要仅仅完成任务!笔试不是高考!到处要显出牛!

说出几个开源软件?MySQL、Linux、 Discuz、Apache、Paint.Net、Android、Chrome、Notepad++……

开源项目有一些是开发包。开源软件指的是能够直接用的。Jquery、NPOI、ASP.Net MVC、Silverlight  Toolkit、AJAX toolkit、json.net

4三、编写一个单例(Singleton)类。

把构造函数设置为private,设置一个public、static的对象实例

public FileManager

{

private FileManager(){}

public readonly static FileManager Instance = new FileManager();

}

扩展:搜“C#  Singleton”,有线程安全的更牛B的实现

4四、什么是sql注入?如何避免sql注入?

用户根据系统的程序构造非法的参数从而致使程序执行不是程序员指望的恶意SQL语句。使用参数化的SQL就能够避免SQL注入。

详细参考复习ppt。举例子,摆事实!1' or 1=1

4五、数据库三范式是什么?

用本身的话解释,而不是背概念。

第一范式:字段不能有冗余信息,全部字段都是必不可少的。

第二范式:知足第一范式而且表必须有主键。

第三范式:知足第二范式而且表引用其余的表必须经过主键引用。

员工内部→本身的老大→外部的老大      记忆顺序:本身内部不重复→别人引用本身→本身引用别人。

4六、post、get的区别

get的参数会显示在浏览器地址栏中,而post的参数不会显示在浏览器地址栏中;

使用post提交的页面在点击【刷新】按钮的时候浏览器通常会提示“是否从新提交”,而get则不会;

get的页面能够被搜索引擎抓取,而用post的则不能够;

post能够提交的数据量很是大,而用get能够提交的数据量则很是小(2k),受限于网页地址的长度。

post能够进行文件的提交,而用get则不能够。

参考阅读:http://www.cnblogs.com/skynet/archive/2010/05/18/1738301.html

4七、.Net、ASP.Net、C#、VisualStudio之间的关系是什么?

答:.Net通常指的是.Net Framework,提供了基础的.Net类,这些类能够被任何一种.Net编程语言调用,.Net Framework还提供了CLR、JIT、GC等基础功能。

ASP.Net是.Net中用来进行Web开发的一种技术,ASP.Net的页面部分写在aspx 文件中,逻辑代码一般经过Code-behind的方式用C#、VB.Net等支持.Net的语言编写。

C#是使用最普遍的支持.Net的编程语言。除了C#还有VB.Net、IronPython等。

VisualStudio是微软提供的用来进行.Net开发的集成开发环境(IDE),使用VisualStudio能够简化不少工做,不用程序员直接调用csc.exe等命令行进行程序的编译,并且VisualStudio提供了代码自动完成、代码高亮等功能方便开发。除了VisualStudio,还有SharpDevelop、MonoDevelop等免费、开源的IDE,VisualStudio Express版这个免费版本。

4八、AJAX解决什么问题?如何使用AJAX?AJAX有什么问题须要注意?项目中哪里用到了AJAX?

答:AJAX解决的问题就是“无刷新更新页面”,用传统的HTML表单方式进行页面的更新时,每次都要将请求提交到服务器,服务器返回后再重绘界面,这样界面就会经历:提交→变白→从新显示这样一个过程,用户体验很是差,使用AJAX则不会致使页面从新提交、刷新。

AJAX最本质的实现是在Javascript中使用XMLHttpRequest进行Http的请求,开发中一般使用UpdatePanel、JQuery等方式简化AJAX的开发,UpdatePanel的方式实现AJAX最简单,可是数据通信量比较大,由于要来回传整个ViewState,并且不灵活,对于复杂的需求则可使用JQuery提供的ajax功能。

UpdatePanel的内部原理。

AJAX最重要的问题是没法跨域请求(www.rupeng.com →so.rupeng.com),也就是没法在页面中向和当前域名不一样的页面发送请求,可使用在当前页面所在的域的服务端作代理页面的方式解决。

在如鹏网项目中发帖的时候显示相关帖的功能、站内搜索项目中显示搜索Suggestion、数据采集项目中都用到了AJAX。

常考:不用任何框架编写一个AJAX程序。XHR:XmlHttpRequest。背也要背下来!

若是面试的时候谈AJAX谈到UpdatePanel的时候,就是NB的时候!!!先侃UpdatePanel的原理!引出为何Dom操做的动态效果在用UpdatePanel提交刷新之后没有了,以及CKEditor被套在UpdatePanel中提交之后也变成了textarea,为何把Fileupload放到Updatepanel中没法实现无刷新上传。说成是公司内部的一个菜鸟用UpdatePanel遇到这样问题,因为我懂XHR、UpdatePanel的原理,因此轻松解决!UpdatePanel生成的上万行JS脚本,不适合于互联网项目。“WebForm怎么可能把开发人员编程傻子呢!不明白原理苦命呀!仍是MVC好呀,MVC。。。。。。。”

4九、Application Cookie Session 两种会话有什么不一样

答:Application是用来存取整个网站全局的信息,而Session是用来存取与具体某个访问者关联的信息。Cookie是保存在客户端的,机密信息不能保存在Cookie中,只能放小数据;Session是保存在服务器端的,比较安全,能够放大数据。

谈到Session的时候就侃Session和Cookie的关系:Cookie中的SessionId。和别人对比说本身懂这个原理而给工做带来的方便之处。

50、开放式问题:你常常访问的技术类的网站是什么?

博客园(www.cnblogs.com)、csdn、codeplex、codeproject、msdn文档、msdn论坛(遇到问题先到网上搜解决方案,还不行就问同事,同事也解决不了就去MSDN论坛提问,必定能获得解决)。Cnbeta.com。

5一、你对.net的GC的理解

GC是.Net的垃圾收集器,能够进行内存资源的回收,程序员无需关心资源的回收,当一个对象没有任何引用的时候就能够被回收了。一个对象能够被回收并不意味着必定会被当即回收,GC会选择时机进行回收。能够调用GC.Collect()让GC当即回收。GC不能回收非托管资源,对于非托管资源通常都实现了IDisposable接口,而后使用using关键字进行资源的回收。

5二、请你简单的说明数据库创建索引的优缺点

使用索引能够加快数据的查询速度,不过因为数据插入过程当中会建索引,因此会下降数据的插入、更新速度,索引还会占磁盘空间。

5三、不用JQuery等框架实现AJAX无刷新登陆。(常考)

提示:用纯XMLHttpRequest实现。

5四、Http状态码各是什么意思。

301(永久重定向)、302 :重定向
404 :页面不存在

500:服务器内部错误

5五、Session有什么重大BUG,微软提出了什么方法加以解决?(常考)

iis中因为有进程回收机制,系统繁忙的话Session会丢失,IIS重启也会形成Session丢失。这样用户就要从新登陆或者从新添加购物车、验证码等放到Session中的信息。能够用State  server或SQL Server数据库的方式存储Session不过这种方式比较慢,并且没法捕获Session的END事件。可是(必定要写上,这样才够拽)我认为这不是Bug,只能说是In-Proc方式存储Session的缺陷,缺陷是和Bug不同的,In-Proc方式存储Session会由服务器来决定何时释放Session,这是By Design,In-Proc方式不知足要求的话彻底能够用StateServer和数据库的方式。

StateServer还能够解决集群Session共享的问题。

5六、asp.net中<%%>、<%=%>、<%#%>的区别是什么

<%%>是执行<%%>中的C#代码,<%=%>是将=后表达式的值输出到Response中,<%#%>是数据绑定,通常用在ListView、GridView、Repeater等控件的绑定中。数据绑定分为:Eval:单向绑定和Bind:双向绑定。

5七、说说在软件设计中你遇到的以空间换时间的例子?

参考回答:谈Cache(缓存)、索引这些例子。用额外的磁盘、内存空间的消耗来提升执行速度。Lucene.Net也是一个例子。

5八、asp.net中的错误机制。(常考)

参考:

定制错误页来将显示一个友好的报错页面。

页面中未捕获同样会触发Page_Error(不经常使用),应用程序中的未捕获异常会触发Application_Error。经过HttpContext.Current.Server.GetLastError()、HttpContext.Current.Error;拿到未捕捉异常,记录到Log4Net日志中

5九、介绍几个使用过的开源的项目

Lucene.net、NPOI、JQuery、ASP.Net AJAX  toolkit、Quartz.Net、JqueryUI、ASP.Net MVC。在CodePlex、SourceForge等网站上有更多的开源项目

60、说出五个集合类

List、Dictionary、Set、Stack(先入后出)、Queue(先入先出)、Tree等。

6一、有一个10个数的数组,计算其中不重复数字的个数。{3,5,9,8,10,5,3}

工程化的非最优解答:用HashSet或者List

int[] values = { 3, 5, 9, 8, 10, 5, 3 };

HashSet<int> set = new HashSet<int>();

foreach (int i in values)

{

set.Add(i);

}

Console.WriteLine(set.Count);

6二、说一下SQLServer中索引的两种类型(常考!!!)

参考:聚簇(或者叫作汇集,cluster)索引和非聚簇索引。

字典的拼音目录就是聚簇(cluster)索引,笔画目录就是非聚簇索引。这样查询“G到M的汉字”就很是快,而查询“6划到8划的字”则慢。

聚簇索引是一种特殊索引,它使数据按照索引的排序顺序存放表中。聚簇索引相似于字典,即全部词条在字典中都以字母顺序排列。聚簇索引实际上重组了表中的数据,因此你只能在表中创建一个聚簇索引。
当数据按值的范围查询时,聚簇索引就显得特别有用。由于全部SQLServer都必需先找到所查询范围的第一行,而后依次下去,直到该范围的最后一个值找到为止,而且保证了全部其余值也落在这个范围内。举一个例子,一个应用程序要查找首字母位于G和P之间的姓名列表,SQLServer首先找到以字母G开头的名字,取出全部记录,直到找到以字母P开头的名字为止,这种方法使得查询过程很是高效。

进行大量数据改动的表不适宜用聚簇索引,由于SQLServer将不得不在表中维护行的次序。若是要索引的值极少,例如一个列包含的全都是1和0,建立聚簇索引就不是个好主意。若是表常常由一个指定的列来排序,该列将是簇索引的最佳候选列。这是由于表中的数据已经为你排好序了。若是访问一个表并使用BETWEEN、<、>、>=或<=操做符来返回一个范围的值时,应该考虑使用聚簇索引。

6三、可否脱离VS用相似editplus的工具手写代码?你以为如何才能提升代码的效率和性能?

能够,使用CSC.exe 来编译.cs文件!

能够根据业务流程、业务数据的特色进行优化,好比能够采用缓存、索引、表驱动等来提高代码的效率和性能,同时不要进行无心义的代码优化,重点优化系统的性能瓶颈。

6四、如何提升页面的显示速度?假如一个页面的加载时间是10.89s,你会用什么样的方式进行优化?

回答要大气!显得很牛!

提示:分而治之的思想。

首先要找出问题所在,是服务器端运行的速度慢仍是服务器端到客户端的下载慢仍是页面在浏览器的加载速度慢。

若是是服务器端运行速度慢,则找是数据库的缘由仍是算法的问题,若是是数据库的问题则尝试添加索引、优化SQL语句,若是是算法的问题,则优化算法。若是对于一些不常常改动的页面可使用静态页技术!对于一些数据不须要及时更新的并且取数据的过程很是耗时可使用缓存。页面中的内容能够按需加载(好比说能够像verycd网站的评论那样当用户须要看的时候再加载其内容),能够在图片须要显示的时候再进行加载。

若是是服务器端到客户端的下载慢则看是页面体积过于臃肿仍是网络问题,若是是页面体积过于臃肿,则优化HTML代码,去掉无用的标签,压缩JS、CSS,能够用CSS Spirit技术将多个图片放到一个图片中,减小向服务器的请求。若是是网络问题,则尝试在不一样的网络、地区部署服务器,而后使用CDN技术加速访问。

若是是页面中的JavaScript运行复杂致使运行速度慢,则优化JavaScript。

webkaka:测网速。

如何处理百万条数据的优化?

对于常常进行检索的字段建立索引,对于常常进行范围查询的一个字段建立汇集索引;

当有大量数据进行插入的时候进行批量插入;

一些代码用存储过程进行重写(当一个逻辑有多行SQL要执行的时候用存储过程能够优化速度,能够避免客户端和SQLServer之间屡次交互);

(*)集群、读写分离;

(*)分区、分表;

6五、在程序编码的时候,你会对Sql注入漏洞的防范采起什么样的措施?

尽可能不要拼SQL语句!使用参数化查询或存储过程能够防止SQL注入攻击!在必须用SQL拼接的地方对用户输入的内容进行检查、过滤。

6六、你会采用什么样的策略和方法来实现系统缓存?

ASP.NET中 缓存有 页面缓存,数据源缓存,和一些本身定义的缓存!

对于那些整个页面不常常变化的咱们可使用页面缓存,而对于那些执行很是耗时的SQL语句而且数据的及时性要求不高的咱们可使用数据源缓存。

对于页面缓存、数据源缓存等都不知足要求的状况下采用直接操做HttpRuntime.Cache来自定义缓存策略。若是须要用多台Web服务器做为一个集群来承载网站的状况,则能够部署专门的分布式缓存服务器,好比Memcached

6七、网站想要实现文件防盗链的功能,说说你的解决方案。

读取HTTP报文头中的UrlReferrer在Application_BeginRequest中咱们能够判断用户的请求是否来源于本网站。若是不是咱们能够终止用户的请求(Response.End();)!

6八、ref与out的区别?

Ref和Out这样个2个关键字都可以提供类似的功效,其做用也很像C中的指针变量。稍有不相同之处是:
Ref型参数时,传入的参数必须先被初始化。而Out则不要要,对Out而言,就必须在方法中对其完成初始化。
Ref和Out时都必须注意,在方法的参数和执行方法时,都要加Ref或Out关键字。以知足匹配。
Out更适合用在要要Return多个返回值的地方,而Ref则用在要要被调出使用的方法修改调出使用者的引用的时候。

6九、MVC路由理解?

一、首先咱们要理解MVC中路由的做用:url Routing的做用是将浏览器的URL请求映射到特定的MVC控制器动做。

二、当咱们访问http://localhost:8080/Home/Index这个地址的时候,请求首先被UrlRoutingModule截获,截获请求后,从Routes中获得与当前请求URL相符合的RouteData对象,将RouteData对象和当前URL封装成一个RequestContext对象,而后从Requestcontext封装的RouteData中获得Controller名字,根据Controller的名字,经过反射建立控制器对象,这个时候控制器才真正被激活,最后去执行控制器里面对应的action。

70、谈谈你以为作的不错系统,大概介绍下用到了哪些技术?

就拿我以前作过的一个项目为例来简单说明一下吧。项目分为客户端和服务端,客户端分为BS客户端和CS客户端,BS客户端采用MVC 5.0的框架,CS客户端是Winform项目,服务端使用WebApi统一提供服务接口,考虑之后可能还要扩展手机端,因此服务接口的参数和返回值使用通用的Json格式来传递数据。

一、服务端采用的面向接口编程,咱们在软件架构的过程当中,层和层之间经过接口依赖,下层不是直接给上层提供实现,而是提供接口,具体的实现以依赖注入的方式在运行的时候动态注入进去。MEF就是实现依赖注入的一种组件。它的使用使得UI层不直接依赖于BLL层,而是依赖于中间的一个IBLL层,在程序运行的时候,经过MEF动态将BLL里面的实现注入到UI层里面去,这样作的好处是减小了层与层之间的耦合。服务端的异常里面、权限验证、日志记录等通用功能使用了AOP拦截的机制统一管理,项目中使用的是Postsharp这个组件,很好地将通用需求功能从不相关的类当中分离出来,提升了代码的可维护性。

二、BS的客户端采用的jquery+bootstrap 的方式,全部页面采用流式布局,能更好适应各类不一样的终端设备(PC、手机)。项目中使用了各类功能强大的bootstrap组件,能适应各类复杂的业务需求。

7一、谈谈你对设计模式的认识?结合你用得最多的一种设计模式说说它的使用。

7二、IIS的工做原理?

一、当客户端发送HTTP Request时,服务端的HTTP.sys(能够理解为IIS的一个监听组件) 拦截到这个请求;

二、HTTP.sys 联系 WAS 向配置存储中心请求配置信息。

三、而后将请求传入IIS的应用程序池。

四、检查请求的后缀,启动aspnet_isapi.dll这个dll,这个dll是.net framework里面的,也就是说到这一步,请求进入了.net framework的管辖范围。

五、这个时候若是是WebForm,开始执行复杂的页面生命周期(HttpRuntime→ProcessRequest→HttpContext→HttpHandler);若是是MVC,则启动mvc的路由机制,根据路由规则为URL来指定HttpHandler。

六、httpHandler处理请求后,请求结束,给出Response,客户端处理响应,整个过程结束。

7三、Http协议

一、http协议是浏览器和服务器双方共同遵循的规范,是一种基于TCP/IP应用层协议。

二、http是一种典型的请求/响应协议。客户端发送请求,请求的内容以及参数存放到请求报文里面,服务端收到请求后,作出响应,返回响应的结果放到响应报文里面。经过F12能够查看请求报文和响应报文。

三、http协议是”无状态”的,当客户端向服务端发送一次http请求后,服务端收到请求而后返回给客户端相应的结果,服务器会当即断开链接并释放资源。在实际开发过程当中,咱们有时须要“保持”这种状态,因此衍生出了Session/Cookie这些技术。

四、http请求的方式主要有get/post。

五、http状态码最好记几个,博主有一次面试就被问到了。200(请求成功)、404(请求的资源不存在)、403(禁止访问)、5xx(服务端错误)

7四、数据库优化经验(后端工程师很是常见)

一、数据库运维方面的优化:启用数据库缓存。对于一些比较经常使用的查询能够采用数据库缓存的机制,部署的时候须要注意设置好缓存依赖项,防止“过时”数据的产生。

二、数据库索引方面的优化:好比经常使用的字段建索引,联合查询考虑联合索引。(PS:若是你有基础,能够敞开谈谈汇集索引和非汇集索引的使用场景和区别)

三、数据库查询方面的优化:避免select * 的写法、尽可能不用in和not in 这种耗性能的用法等等。

四、数据库算法方面的优化:尽可能避免大事务操做、减小循环算法,对于大数据量的操做,避免使用游标的用法等等。

7五、关于代码优化你怎么理解?你会考虑去代码重构吗?

一、对于代码优化,以前的公司每周会作代码审核,审核的主要做用就是保证代码的正确性和执行效率,好比减小代码的层级结构、避免循环嵌套、避免循环CURD数据库、尽可能避免一次取出大量数据放在内存中(容易内存溢出)、优化算法等。

二、对于陈旧代码,可能不少地方有调用,而且开发和维护人员颇有可能不是同一我的,因此重构时要格外当心,若是没有十足的把握,不要轻易重构。若是必需要重构,必须作好充分的单元测试和全局测试。

7六、关于服务器端 MVC 架构的技术实现,您是怎样理解的?这种架构方式有什么好处?您在项目中是如何应用这一架构的?

参考答案:MVC,顾名思义,Model、View、Controller。全部的界面代码放在View里面,全部涉及和界面交互以及URL路由相关的逻辑都在Controller里面,Model提供数据模型。MVC的架构方式会让系统的可维护性更高,使得每一部分更加专一本身的职责,而且MVC提供了强大的路由机制,方便了页面切换和界面交互。而后能够结合和WebForm的比较,谈谈MVC如何解决复杂的控件树生成、如何避免了复杂的页面生命周期。

7七、网站优化:网站运行慢,如何定位问题?发现问题如何解决?

浏览器F12→网络→查看http请求数以及每一个请求的耗时,找到问题的根源,而后依次解决,解决方案能够参考问题一里面的Web优化方案。

7八、说说你最擅长的技术?并说说你是如何使用的?

简单谈谈MEF在咱们项目里面的使用吧。

在谈MEF以前,咱们必需要先谈谈DIP、IOC、DI

依赖倒置原则(DIP):一种软件架构设计的原则(抽象概念)

控制反转(IoC):一种反转流、依赖和接口的方式(DIP的具体实现方式)。

依赖注入(DI):IoC的一种实现方式,用来反转依赖(IoC的具体实现方式)。

什么意思呢?也就是说,咱们在软件架构的过程当中,层和层之间经过接口依赖,下层不是直接给上层提供实现,而是提供接口,具体的实现以依赖注入的方式在运行的时候动态注入进去。MEF就是实现依赖注入的一种组件。它的使用使得UI层不直接依赖于BLL层,而是依赖于中间的一个IBLL层,在程序运行的时候,经过MEF动态将BLL里面的实现注入到UI层里面去,这样作的好处是减小了层与层之间的耦合。这也正是面向接口编程方式的体现。

7九、本身写过多线程组件吗?简要说明!

参考答案:能够参考http://www.cnblogs.com/Alexander-Lee/archive/2009/10/31/1593647.html

80、谈谈ERP、CRM、MES、OA类型系统的不一样

ERP:Enterprise Resource Planning,企业资源计划。是指创建在信息技术基础上,以系统化的管理思想,为企业决策层及员工提供决策运行手段的管理平台。

CRM:Customer Relationship Management,客户关系管理。是一种以"客户关系一对一理论"为基础,旨在改善企业与客户之间关系的新型管理机制。

MES:manufacturing execution system,生产执行系统。是一套面向制造企业车间执行层的生产信息化管理系统

OA:Office Automation,办公自动化。将现代化办公和计算机网络功能结合起来的一种新型的办公方式

8一、如何处理几十万条并发数据?

答:用存储过程或事务。取得最大标识的时候同时更新..注意主键不是自增量方式这种方法并发的时候是不会有重复主键的..取得最大标识要有一个存储过程来获取.

8二、ASP.Net页面生命周期简单描述

 

每一个页面的生命周期为用户的每一次访问,也就是说每一次客户端与服务器之间的一个往返过程.全局变量的生命周期在此之间.

1. Page_Init();

2. Load ViewState and Postback data;

3. Page_Load();

4. Handle control events;

5. Page_PreRender();

6. Page_Render();

7. Unload event;

8. Dispose method called;

================================================================================

相关文章
相关标签/搜索