为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

.NET绝版面试题

2011-01-03 27页 doc 119KB 18阅读

用户头像

is_480042

暂无简介

举报
.NET绝版面试题.net绝版面试题 本人在深圳面试十来家,发现百分之八十的题目都是来之于以下题目,今天分享给大家,好好背吧. 1、@page指令只能在_aspx___文件(填写扩展名)中使用,而@Control指令只能用在_ascx___文件(填写扩展名)中使用. 2、说明控件DataGrid,DataTable,DataView,DetailsView,formView,Repeator常用属性,如果要想把一条记录分成两列显示,以上控件哪些可以用,哪些不可以用?如果可用,如何处理? 答:DataMember:绑定的表或者视图,DataSou...
.NET绝版面试题
.net绝版面试题 本人在深圳面试十来家,发现百分之八十的题目都是来之于以下题目,今天分享给大家,好好背吧. 1、@page指令只能在_aspx___文件(填写扩展名)中使用,而@Control指令只能用在_ascx___文件(填写扩展名)中使用. 2、说明控件DataGrid,DataTable,DataView,DetailsView,formView,Repeator常用属性,如果要想把一条分成两列显示,以上控件哪些可以用,哪些不可以用?如果可用,如何处理? 答:DataMember:绑定的表或者视图,DataSourseID:数据源控制的ID,Visible:是否显示该控件. FormView,Repeator可以用,其他的控件不能可用,在ItemTemplate模板里用或者用列表来显示. 3、写出下列的含义 <% %>,<%# %>, 答:<% %>是服务器端代码块    <%# %>表示绑定的数据源 4、请解释Page.IsPostBack,Response.Write,Response.End,DBNull.Value, DataSet,DataTable,DataView,SqlDataReader,stringbuilder,ArrayList?    Page.IsPostBack:是否正是被首次加载    Response.Write:打印指定的文本    Response.End:停止当前的程序并返回结果    DBNull是一个类。DBNull.Value是它唯一的实例。它指数据库中数据为空()时,在.net中的值。    DataSet:DataSet是数据在内存中的表示形式,是不依赖与数据库的独立数据集合.    DataTable:是一个包含列和行表.    DataView:数据视图    SqlDataReader:提供一种从 SQL Server 数据库读取行的只进流的方式。  5、 stringbuilder:StringBuffer线程安全的可变字符序列。一个类似于 String 的字符串缓冲区,但不能修改。虽然在任意时间点上它都包含某种特定的字符序列,但通过某些方法调用可以改变该序列的长度和内容。    ArrayList:动态加载的数组    partial,protected,private,public的含义:    答:partial:仅所属类的成员才可以访问       protected:可被所属的类或派生自所属类的类型访问       public:访问不受限制。 6、如何理解死锁的概念?死锁是如何形成的?在应用中应注意什么事项避免死锁? 死锁是一种条件,不仅仅是在关系数据库管理系统 (RDBMS) 中发生,在任何多用户系统中都可以发生的。当两个用户(或会话)具有不同对象的锁,并且每个用户需要另一个对象的锁时,就会出现死锁。每个用户都等待另一个用户释放他的锁。当两个连接陷入死锁时,Microsoft? SQL Server? 会进行检测。其中一个连接被选作死锁牺牲品。该连接的事务回滚,同时应用程序收到错误。 阻塞   任何基于锁的并发系统都不可避免地具有可能在某些情况下发生阻塞的特征。当一个连接控制了一个锁,而另一个连接需要冲突的锁类型时,将发生阻塞。其结果是强制第二个连接等待,或在第一个连接上阻塞。 其实所有的死锁最深层的原因就是一个——资源竞争。 表现一: 一个用户A 访问表A(锁住了表A),然后又访问表B,另一个用户B 访问表B(锁住了表B),然后企图访问表A。这时用户A由于用户B已经锁住表B,它必须等待用户B释放表B,才能继续,好了他老人家就只好老老实实在这等了。 同样用户B要等用户A释放表A才能继续这就死锁了。 解决方法: 这种死锁是由于你的程序的BUG产生的,除了调整你的程序的逻辑别无他法。 仔细分析你程序的逻辑: 1:尽量避免同时锁定两个资源; 2: 必须同时锁定两个资源时,要保证在任何时刻都应该按照相同的顺序来锁定资源。 表现二: 用户A读一条纪录,然后修改该条纪录,这是用户B修改该条纪录,这里用户A的事务里锁的性质由共享锁企图上升到独占锁(for update),而用户B里的独占锁由于A有共享锁存在所以必须等A释放掉共享锁,而A由于B的独占锁而无法上升的独占锁也就不可能释放共享锁,于是出现了死锁。 这种死锁比较隐蔽,但其实在稍大点的项目中经常发生。 解决方法: 让用户A的事务(即先读后写类型的操作),在select 时就是用Update lock 7、什么是事务? 使用事务的语句有哪些? 答:事务是一种机制,是一个操作序列,它包括了一组数据库操作命令,并且所有的命令作为一个整体向     系统提交或者撤消操作请求,要么全部,要么全部不执行.     begin transaction     commit transaction     rollback transaction 8、在update触发器中如何使用修改前,后的数据?    if   update(字段1)     begin     ...     end   9、有一职员表,字段有工卡和姓名,写出所有姓名重复的职员信息的SQL 语句。   答:select * from test where name in(     select name from test  group by name having  count(name)>1)   10、有两张表Table1,Table2 ,都只有一个字段。Table有数据'1','2','3','4',Table2有'1','3'.写出一句通用Sql语句将表Table1的记录同步到Table2中!。    答: insert table2 (字段) select '2' union select '4'; 11、请谈谈你对OOP的理解。 面向对象编程(Object Oriented Programming,OOP,面向对象程序)是一种计算机编程架构。OOP 的一条基本原则是计算机程序是由单个能够起到子程序作用的单元或对象组合而成。OOP 达到了软件工程的三个主要目标:重用性、灵活性和扩展性。为了实现整体运算,每个对象都能够接收信息、处理数据和向其它对象发送信息。OOP 主要有以下的概念和组件:   组件 -数据和功能一起在运行着的计算机程序中形成的单元,组件在 OOP 计算机程序中是模块和结构化的基础。   抽象性 -程序有能力忽略正在处理中信息的某些方面,即对信息主要方面关注的能力。   封装 -也叫做信息封装:确保组件不会以不可预期的方式改变其它组件的内部状态;只有在那些提供了内部状态改变方法的组件中,才可以访问其内部状态。每类组件都提供了一个与其它组件联系的接口,并规定了其它组件进行调用的方法。   多态性 -组件的引用和类集会涉及到其它许多不同类型的组件,而且引用组件所产生的结果得依据实际调用的类型。 继承性 - 允许在现存的组件基础上创建子类组件,这统一并增强了多态性和封装性。典型地来说就是用类来对组件进行分组,而且还可以定义新类为现存的类的扩展,这样就可以将类组织成树形或网状结构,这体现了动作的通用性。 12、 简述 private、 protected、 public、 internal 修饰符的访问权限。 private : 私有成员, 在类的内部才可以访问。protected : 保护成员,该类内部和继承类中可以访问。public : 公共成员,完全公开,没有访问限制。internal: 在同一命名空间内可以访问。 13、 写出一条Sql语句: 取出表A中第31到第40记录(SQLServer, 以自动增长的ID作为主键, 注意:ID可能不是连续的。) select row,name from(select row_number() over(order by id) as row,name from A) as AWithRowNumber where row >=31 and row<=40  14、列举ASP.NET 页面之间传递值的几种方式。  1.     使用QueryString, 如....?id=1; response. Redirect(),这种方法的主要优点是实现起来非常简单,然而它的缺点是传递的值是会显示在浏览器的地址栏上的(不安全),同时又不能传递对象  2.使用Session变量,缺点是在Session变量存储过多的数据会消耗比较多的服务器资源,最好的解决办法是用完session,用remove删除 3.使用Server.Transfer,将要传递的数据使用get方法封装,在另一个页面以对象属性的方式来存取显露的值,在目标页面实例源页面,WebForm1 wf1;wf1=(WebForm1)Context.Handler;Label1.Text=wf1.Name;Label2.Text=wf1.EMail;  2。请说明在.net中常用的几种页面间传递参数的方法,并说出他们的优缺点。  session(viewstate) 简单,但易丢失  application 全局  cookie 简单,但可能不支持,可能被伪造  input ttype="hidden" 简单,可能被伪造  url参数简单,显示于地址栏,长度有限  数据库稳定,安全,但性能相对弱 15、override与重载的区别 Override用来重写父类的方法,重载使用相同名的方法或操作符拥有不同类型的参数,重写是子类的方法覆盖父类的方法,要求方法名和参数都相同 ,重载是在同一个类中的两个或两个以上的方法,拥有相同的方法名,但是参数却不相同,方法体也不相同,最常见的重载的例子就是类的构造函数 16、.net的错误处理机制是什么 .net错误处理机制采用try->catch->finally结构,发生错误时,层层上抛,直到找到匹配的Catch为止。 17、C#中接口和类的异同 接口和类都是类,不同的是,接口只包含方法或属性的声明,不包含具体实现方法的代码,接口可以实现多继承,而类只能是单继承,继承接口的类必须实现接口中声明的方法或属性。接口主要定义一种,统一调用方法,在大型项目中接口正发挥日益重要的作用。 18、DataReader和DataSet的异同 DataReader和DataSet最大的区别在于,DataReader使用时始终占用SqlConnection,在线操作数据库..任何对SqlConnection的操作都会引发DataReader的异常..因为DataReader每次只在内存中加载一条数据,所以占用的内存是很小的..因为DataReader的特殊性和高性能.所以DataReader是只进的..你读了第一条后就不能再去读取第一条了.. DataSet则是将数据一次性加载在内存中.抛弃数据库连接..读取完毕即放弃数据库连接..因为DataSet将数据全部加载在内存中.所以比较消耗内存...但是确比DataReader要灵活..可以动态的添加行,列,数据.对数据库进行回传更新操作... 19、    在c#中using和new这两个关键字有什么意义,请写出你所知道的意义? Using 引入一个名子空间,或在使用了一个对像后自动调用其IDespose,New 实例化一个对像,或修饰一个方法,表此方法完全重写此方法 20、谈谈类和结构的区别? 最大区别一个是引用类型,一个是值类型 默认成员访问为public是另外一个区别 21、 在.net(C# or vb.net)中如何获得当前窗体或控件的句柄,特别是控件本身的句柄(请列举)。 this(C#) Me(vb.net). 22、在.net(C# or vb.net)中如何用户自定义消息,并在窗体中处理这些消息。 在form中重载DefWndProc函数来处理消息: protected override void DefWndProc ( ref System.WinForms.Message m )  {  switch(m.msg)  {  case WM_Lbutton :   ///string与MFC中的CString的Format函数的使用方法有所不同   string message = string.Format("收到消息!参数为:{0},{1}",m.wParam,m.lParam);   MessageBox.Show(message);///显示一个消息框   break;  case USER: 处理的代码 default:   base.DefWndProc(ref m);///调用基类函数处理非自定义消息。   break;  }  } 23、 在.net(C# or vb.net)如何启动另一个程序。process 24、 在.net(C# or vb.net)中如何取消一个窗体的关闭 private void Form1_Closing(object sender, System.ComponentModel.CancelEventArgs e) { e.Cancel=true; } 25、 在.net(C# or vb.net)中,Appplication.Exit 还是 Form.Close有什么不同? 答案:一个是退出整个应用程序,一个是关闭其中一个form 27、在C#中有一个double型的变量,比如10321.5,比如122235401.21644,作为货币的值如何按各个不同国家的习惯来输出。比如美国用$10,321.50和$122,235,401.22而在英国则为£10 321.50和£122 235 401.22 答案: System.Globalization.CultureInfo MyCulture = new System.Globalization.CultureInfo("en-US"); //System.Globalization.CultureInfo MyCulture = new System.Globalization.CultureInfo("en-GB");为英国货币类型 decimal y = 9999999999999999999999999999m; string str = String.Format(MyCulture,"My amount = {0:c}",y); 28、 62-63=1 等式不成立,请移动一个数字(不可以移动减号和等于号),使得等式成立,如何移动? 答案:62移动成2的6次方 29、new有几种用法 第一种:new Class(); 第二种:覆盖方法 public new XXXX(){} 第三种:new 约束指定泛型类声明中的任何类型参数都必须有公共的无参数构造函数。 30、如何把一个array复制到arrayList里 foreach( object o in array )arrayList.Add(o); 31、datagrid.datasouse可以连接什么数据源 [dataset,datatable,dataview] dataset,datatable,dataview , IList 32、概述反射和序列化 反射:程序集包含模块,而模块包含类型,类型又包含成员。反射则提供了封装程序集、模块和类型的对象。您可以使用反射动态地创建类型的实例,将类型绑定到现有对象,或从现有对象中获取类型。然后,可以调用类型的方法或访问其字段和属性 序列化:序列化是将对象转换为容易传输的格式的过程。例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象。在另一端,反序列化将从该流重新构造对象。 33、概述o/r mapping 的原理 利用反射,配置 将类于数据库表映射 34、用sealed修饰的类有什么特点 sealed 修饰符用于防止从所修饰的类派生出其它类。如果一个密封类被指定为其它类的基类,则会发生编译时错误。 密封类不能同时为抽象类。 sealed 修饰符主要用于防止非有意的派生,但是它还能促使某些运行时优化。具体说来,由于密封类永远不会有任何派生类,所以对密封类的实例的虚拟函数成员的调用可以转换为非虚拟调用来处理。 35、详述.NET里class和struct的异同! class:放在 ? struct放在? struct值传递 类与结构有很多相似之处:结构可以实现接口,并且可以具有与类相同的成员类型。然而,结构在几个重要方面不同于类:结构为值类型而不是引用类型,并且结构不支持继承。结构的值存储在“在堆栈上”或“内联”。细心的程序员有时可以通过聪明地使用结构来增强性能。 36、概述.NET里对 remoting 和 webservice 两项技术的理解和实际中的应用。 远程逻辑调用,remoing接口只能用在.net中 37、什么是code-behind技术   aspx and cs 38、概述三层结构体系        web/business/dataaccess 39、asp.net如何实现MVC模式,举例说明! web/business/dataaccess 40、什么是ASP.net中的用户控件 答:用户控件就是.ascx扩展名的东西喽,可以拖到不同的页面中调用,以节省代码.比如登陆可能在多个页面上有,就可以做成用户控件,但是有一个问题就是用户控件拖到不同级别的目录下后里面的图片等的相对路径会变得不准确,需要自已写方法调整. 41、什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS、CLS和CLR分别作何解释? 答:装箱就是把值类型转成引用类型,从MS IL角度看好像是boxing,没记错的话是把值从堆栈转到堆中.拆箱相反,重载就是指一个方法名同,参数个数不同,返回值可以相同的方法. CLR(公用语言运行时) CLS(共语言规范) CTS(通用类型系统) 42、列举一下你所了解的XML技术及其应用 答:XML可是好东西,保存配置,站与站之间的交流,WEB SERVICE都要用它. 43、值类型和引用类型的区别?写出C#的样例代码。 答:结构是值类型,类是引用类型,所以传结构就是值类型的应用啦,传对象或类就是引用类型的,这个不用多写了吧. 44、ADO.net中常用的对象有哪些?分别描述一下。 答:connection command sqladapter dataset datatable dataview等等.写不完了. 45、如何理解委托? 答:据说相当于函数指针,定义了委托就可以在不调用原方法名称的情况下调用那个方法. msdn2005中是这样解释的: 委托具有以下特点: 委托类似于 C++ 函数指针,但它是类型安全的。 委托允许将方法作为参数进行传递。 委托可用于定义回调方法。 委托可以链接在一起;例如,可以对一个事件调用多个方法。 方法不需要与委托签名精确匹配。有关更多信息,请参见协变和逆变。 C# 2.0 版引入了匿名方法的概念,此类方法允许将代码块作为参数传递,以代替单独定义的方法。 46、C#中的接口和类有什么异同。 答:接口是负责功能的定义,项目中通过接口来规范类,操作类以及抽象类的概念!  而类是负责功能的具体实现!  在类中也有抽象类的定义,抽象类与接口的区别在于:  抽象类是一个不完全的类,类里面有抽象的方法,属性,也可以有具体的方法和属性,需要进一步的专业化。  但接口是一个行为的规范,里面的所有东西都是抽象的!  一个类只可以继承一个基类也就是父类,但可以实现多个接口 47、.net中读写数据库需要用到哪些类?他们的作用 答:这个类自已可以写的啊,你是指基类吗?那configuration,sqlconnection,sqlcommand等都要用到. 48、UDP连接和TCP连接的异同。 答:前者只管传,不管数据到不到,无须建立连接.后者保证传输的数据准确,须要连结. 49、ASP.net的身份验证方式有哪些?分别是什么原理? 答:form认证,windows集成认证等,原理不清楚. 50、什么是code-Behind技术。 答:代码分离,这是个明智的东西,像ASP这样混成一堆很不爽.或者可以理解成HTML代码写在前台,C#代码写在后台.当然前台也有脚本,类的调用等,其实写在一起也是可以的. 51、.net中读写XML的类都归属于哪些命名空间? 答:System.Xml 52、解释一下UDDI、WSDL的意义及其作用。 答:UDDI即统一描述、发现和集成。作用: 用来说明一个Web服务的一些信息类型,以便帮助服务的请求者确定如下问题: WHO,WHAT,WHERE,HOW . How : 提供的服务质量怎样。 WSDL Web Services Description Language的缩写,是一个用来描述Web服务和说明如何与Web服务通信的XML语言。 WSDL用来提供对服务的描述,它的主要构成要素有五个: 1)Types: 定义WSDL定义中所用到的数据类型,即XML Schema Types 2)Message : 对一组消息的输入和输出参数的定义 3)portType : 定义Web服务的操作 4) Binding :描述特定服务接口的协议、数据格式、安全性和其它属性. 5) Services : 制定特定服务的URL和提供的调用接口,包含一组端口元素  53、.什么是SOAP,有哪些应用。 答:SOAP(Simple Object Access Protocol )简单对象访问协议是在分散或分布式的环境中交换信息并执行远程过程调用的协议,是一个基于XML的协议。使用SOAP,不用考虑任何特定的传输协议(最常用的还是HTTP协议),可以允许任何类型的对象或代码,在任何平台上,以任何一直语言相互通信。这种相互通信采用的是XML格式的消息,具体请看:http://playist.blogchina.com/2521621.html 54、常用的调用webservice方法有哪些? 答:  可以从浏览器、ASP页或其他WEB服务调用可以使用HTTP-GET   HTTP-POST访问WEB服务也可以从ASP页或其他WEB服务向其他WEB服务发出SOAP请求HTTP-GET   HTTP-POST SOAP 使用WEB服务代理 55、 私有程序集与共享程序集有什么区别? 一个私有程序集通常为单个应用程序所使用,并且存储于这个应用程序所在的目录之中,或此目录下面的一个子目录中。共享程序集通常存储在全局程序集缓存(Global Assembly Cache)之中,这是一个由.NET运行时所维护的程序集仓库。共享程序集通常是对许多应用程序都有用的代码库,比如.NET Framework类。 56、 请解释进程与线程的区别?进程与程序的区别? 一般,一个应用程序对应于一个或多个进程,可以把进程看作是该应用程序在*作系统中的标识;而一个进程通常由多个线程组成,而线程是*作系统为该应用程序分配处理时间的最小单元。  57、 CLR与IL分别是什么含义? CLR:公共语言运行时,类似于Java中的JVM,Java虚拟机;在.Net环境下,各种编程语言使用一种共同的基础资源环境,这就是CLR,CLR将直接与*作系统进行通信,而编程语言如C#.NET将尽量避免直接与*作系统直接通信,加强了程序代码的执行安全性,可以这样看:CLR就是具体的编程语言如:C#.NET与*作系统之间的翻译,同时它为具体的编程语言提供了许多资源: IL,中间语言,也称MSIL,微软中间语言,或CIL,通用中间语言;所有.NET源代码(不管用哪种语言编写)在进行编译时都被编译成IL。在应用程序运行时被即时(Just-In-Time,JIT)编译器处理成为机器码,被解释及执行。 58、请解释ASP。NET中以什么方式进行数据验证        Aps.net 中有非空验证,比较验证,取值范围验证,正则表达式验证及客户自定义验证五大控件,另还有一个集中验证信息处理控件 11. WEB控件可以激发服务端事件,请谈谈服务端事件是怎么发生并解释其原理?自动传回是什么?为什么要使用自动传回。 在web控件发生事件时,客户端采用提交的形式将数据交回服务端,服务端先调用Page_Load事件,然后根据传回的状态信息自动调用服务端事件自动传回是当我们在点击客户端控件时,采用提交表单的形式将数据直接传回到务端 只有通过自动传回才能实现服务端事件的机制,如果没有自动回传机制就只能调用客户端事件,而不能调用服务端事件 59、WEB控件及HTML服务端控件能否调用客户端方法?如果能,请解释如何调用? 可以调用 例如: 60、 请解释web.config文件中的重要节点 appSettings包含自定义应用程序设置。 system.web 系统配置 compilation动态调试编译设置 customErrors自定义错误信息设置 authentication身份验证,此节设置应用程序的身份验证策略。 authorization授权, 此节设置应用程序的授权策略. 61、 请解释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" 表用运行时使用哪一个隐藏类 62、 什么是viewstate,能否禁用?是否所用控件都可以禁用? Viewstate是保存状态的一种机制,EnableViewState属性设置为false即可禁用 63、 当发现不能读取页面上的输入的数据时很有可能是什么原因造成的?怎么解决 很有可能是在Page_Load中数据处理时没有进行Page的IsPostBack属性判断 64、 请解释什么是上下文对象,在什么情况下要使用上下文对象 上下文对象是指HttpContext类的Current 属性,当我们在一个普通类中要访问内置对象(Response,Request,Session,Server,Appliction等)时就要以使用此对象 65、 请解释转发与跳转的区别? 转发就是服务端的跳转A页面提交数据到B页面,B页面进行处理然后从服务端跳转到其它页面 跳转就是指客户端的跳转 66、请说明在.net中常用的几种页面间传递参数的方法,并说出他们的优缺点。 session(viewstate) 简单,但易丢失application 全局cookie 简单,但可能不支持,可能被伪造 input ttype="hidden" 简单,可能被伪造url参数简单,显示于地址栏,长度有限,数据库稳定,安全,但性能相对弱 67、DataReader和DataSet的异同 DataReader和DataSet最大的区别在于,DataReader使用时始终占用SqlConnection,在线操作数据库..任何对SqlConnection的操作都会引发DataReader的异常..因为DataReader每次只在内存中加载一条数据,所以占用的内存是很小的..因为DataReader的特殊性和高性能.所以DataReader是只进的..你读了第一条后就不能再去读取第一条了.. DataSet则是将数据一次性加载在内存中.抛弃数据库连接..读取完毕即放弃数据库连接..因为DataSet将数据全部加载在内存中.所以比较消耗内存...但是确比DataReader要灵活..可以动态的添加行,列,数据.对数据库进行回传更新操作... 68、谈谈类和结构的区别? 最大区别一个是引用类型,一个是值类型默认成员访问为public是另外一个区别都要用到. 69、 请解释什么是上下文对象,在什么情况下要使用上下文对象 上下文对象是指HttpContext类的Current 属性,当我们在一个普通类中要访问内置对象(Response,Request,Session,Server,Appliction等)时就要以使用此对象 70、请简述一下用Socket进行同步通讯编程的详细步骤 1、在应用程序和远程设备中使用协议和网络地址初始化套接字 2、在应用程序中通过指定端口和地址建立监听 3、远程设备发出连接请求 4、应用程序接受连接产生通信scoket 5、应用程序和远程设备开始通讯(在通讯中应用程序将挂起直到通讯结束) 6、通讯结束,关闭应用程序和远程设备的Socket回收资源 71、在C#中,string   str   =   null   与   string   str   =   “”   请尽量使用文字或图象说明其中的区别。     string   str   =   null   是不给他分配内存空间,而string   str   =   “”给它分配长度为空字符窜的内存空间.         72、请详述在dotnet中类(class)与结构(struct)的异同:(10分)     Class可以被实例化,属于引用类型,是分配在内存的堆上的,Struct属于值类型,是分配在内存的栈上的.         73、SQLSERVER服务器中,给定表   table1   中有两个字段   ID、LastUpdateDate,ID表示更新的事务号,   LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号。(10)     select   top   ID   from   table1   order   by   LastUpdateData   desc       74、简要谈一下您对微软.NET   构架下remoting和webservice两项技术的理解以及实际中的应用。(10)     remoting是.net   中用来跨越machine,   process,   appdomain   进行方法调用的技术,对于三成结构的程序,就可以使用remoting技术来构建.它是分布应用的基础技术.相当于以前的DCOM  Web   Service是一种构建应用程序的普通模型,并能在所有支持internet网通讯的操作系统上实施。Web   Service令基于组件的开发和web的结合达到最佳,基于组件的对象模型  75、什么叫做SQL注入,如何防止?请举例说明。 利用sql关键字对网站进行攻击。过滤关键字'等 所谓SQL注入(SQL Injection),就是利用程序员对用户输入数据的合法性检测不严或不检测的特点,故意从客户端提交特殊的代码,从而收集程序及服务器的信息,从而获取想得到的资料。 http://localhost/lawjia/show.asp?ID=444 and user>0,这时,服务器运行Select * from 表名 where 字段=444 and user>0这样的查询,当然,这个语句是运行不下去的,肯定出错,错误信息如下:   ·错误类型: Microsoft OLE DB Provider for ODBC Drivers (0x80040E07) [Microsoft][ODBC SQL Server Driver][SQL Server]将 nvarchar 值 'sonybb' 转换为数据类型为 int 的列时发生语法错误。 76、 产生一个int数组,长度为100,并向其中随机插入1-100,并且不能重复。 int[] intArr=new int[100]; ArrayList myList=new ArrayList(); Random rnd=new Random(); while(myList.Count<100) { int num=rnd.Next(1,101); if(!myList.Contains(num)) myList.Add(num); } for(int i=0;i<100;i++) intArr[i]=(int)myList[i];  77、请叙述类与结构的区别。   1)、结构是值类型;   2)、结构不支持继承;   3)、结构不能定义默认的构造函数;   4)、结构不能定义析构函数;   5)、结构不能使用初始值设置域值。 78、维护数据库的完整性、一致性、你喜欢用触发器还是自写业务逻辑?为什么 答:尽可能用约束(包括CHECK、主键、唯一键、外键、非空字段)实现,这种方式的效率最好;其次用触发器,这种方式可以保证无论何种业务系统访问数据库都能维持数据库的完整性、一致性;最后再考虑用自写业务逻辑实现,但这种方式效率最低、编程最复杂,当为下下之策 79、 ADO。NET相对于ADO等主要有什么改进? 答 ADO数据以Recordset 形式存储 ADO.NET以DataSet形式存储 Recordset对数据库持续连接访问ADO.NET提供对数据库断开连接 ADO.NET与ADO相比,优势在于提供了数据集和数据适配器,有利于实现分布式处理,降低对数据库服务器资源的消耗。 80、 ASP。NET与ASP相比,主要有哪些进步? 答 asp.net   可以使用强类型语言  页面是编译,执行速度快, 增加安全性和可靠性 ,通过继承机制来支持代码的重用,提供声明性服务器控件减少代码行数 Asp需要解释,执行速度慢,重用代码不方便,没有调试机制 81、C#中的委托是什么?事件是不是一种委托? 答 委托本质上是一种“方法接口”,它相当于C/C++中的函数指针,当然它比函数指针安全,在C#中通常用于事件处理。与JAVA相比,可以避免使用大量小粒度的匿名类。(不过,也许微软就是使用类似于JAVA的匿名类实现委托的,只不过从字面上看起不是那么回事罢了,谁知道呢?) 事件不是委托,不过由于事件的性质决定了处理它的程序逻辑能访问的参数,因此,在C#中处理事件的逻辑都包装为委托(一种“方法接口”)。实际上,如果你处理自定义的事件,就像JAVA中那样用接口实现也是可以的,不过这么做在C#一般没有什么特别的好处。 82、datagrid.datasouse可以连接什么数据源 答 [dataset,datatable,dataview] dataset,datatable,dataview , IList 83、用sealed修饰的类有什么特点 答 sealed 修饰符用于防止从所修饰的类派生出其它类。如果一个密封类被指定为其他类的基类,则会发生编译时错误。密封类不能同时为抽象类。 sealed 修饰符主要用于防止非有意的派生,但是它还能促使某些运行时优化。具体说来,由于密封类永远不会有任何派生类,所以对密封类的实例的虚拟函数成员的调用可以转换为非虚拟调用来处理。 84、用.net做B/S结构的系统,您是用几层结构来开发,每一层之间的关系以及为什么要这样分层?  答:一般为3层           数据访问层,业务层,表示层。  数据访问层对数据库进行增删查改。  业务层一般分为二层,业务表观层实现与表示层的沟通,业务规则层实现用户密码的安全等。  表示层为了与用户交互例如用户添加表单。  优点:   分工明确,条理清晰,易于调试,而且具有可扩展性。  缺点:   增加成本。 85、什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS、CLS和CLR分别作何解释? 答 应用程序域可以理解为一种轻量级进程。起到安全的作用。占用资源小     受管制的代码:unsafe:非托管代码。不经过CLR运行。     强类型系统 RTTI:类型识别系统。     装箱就是把值类型到引用类型的转换     拆箱就是引用类型到值类型的转换     重载   方法名相同 不用个数的参数或者指定不同参数类型     CTS:通用语言系统。CLS:通用语言规范。CLR:公共语言运行库。 86、ADO.net中常用的对象有哪些?分别描述一下。 答:Connection 对象用于在应用程序和数据库之间的连接     Command   可以检索和操纵数据库中的数据      DataAdapter对象充当DataSet和数据源之间用于检索和保存数据的桥接器     DataSet 对象从数据库检索的数据可以存储在其中能够以XML形式保存     DataReader 是查询结果的一种只进。只读的视图 不具有DataSet的任何复杂功能     所以可以加快访问和查看数据的速度 不提供断开式访问 87、如何理解委托? 答:据说相当于函数指针,定义了委托就可以在不调用原方法名称的情况下调用那个方法. msdn2005中是这样解释的:  委托具有以下特点:委托类似于 C++ 函数指针,但它是类型安全的。 委托允许将方法作为参数进行传递。委托可用于定义回调方法 委托可以链接在一起;例如,可以对一个事件调用多个方法。 方法不需要与委托签名精确匹配。 88、C#中的委托是什么?事件是不是一种委托? 答 委托可以把一个方法作为参数代入另一个方法。  委托可以理解为指向一个函数的引用。  是,是一种特殊的委托 89、进程和线程分别怎么理解? 答:进程是老子,线程是儿子,没有老子就没有儿子,一个老子可以有多个儿子.一个儿子可以成为别人的儿子,一个老子也可以为别的老子生儿子. 90、解释一下UDDI、WSDL的意义及其作用 答:UDDI 用于注册各个服务提供商提供的服务 以便可以共享它们它还有助于WEB服务客户或web用户查找该Web服务 wsdl 是web服务描述语言(web Services Description Language) 91、什么是SOAP,有哪些应用。 答:SOAP(Simple Object Access Protocol )简单对象访问协议是在分散或分布式的环境中交换信息并执行远程过程调用的协议,是一个基于XML的协议。使用SOAP,不用考虑任何特定的传输协议(最常用的还是HTTP协议),可以允许任何类型的对象或代码,在任何平台上,以任何一直语言相互通信。这种相互通信采用的是XML格式的消息,具体请看 92、 概述.NET里对 remoting 和 webservice 两项技术的理解和实际中的应用。 答 远程逻辑调用,remoing接口只能用在.net中 93、 简述 private、 protected、 public、 internal 修饰符的访问权限。  答    private :    私有成员, 在类的内部才可以访问。         protected : 保护成员,该类内部和继承类中可以访问。         public :     公共成员,完全公开,没有访问限制。         internal:    在同一命名空间内可以访问。 94、列举ASP.NET 页面之间传递值的几种方式。   答. 1.使用QueryString,       源页面       string url;        url="anotherwebform.aspx?name=" + TextBox1.Text        Response.Redirect(url);       目标页面        Label1.Text=Request.QueryString["name"];      2.使用Session变量       源页面       Session["name"]=TextBox1.Text;        Session["email"]=TextBox2.Text;       Server.Transfer("anotherwebform.aspx");      目标页面       Label1.Text=Session["name"].ToString();       Label2.Text=Session["email"].ToString();       Session.Remove("name");       Session.Remove("email");      3.使用Server.Transfer        源页面代码:     public string Name { get { return TextBox1.Text; } } //然后调用Server.Transfer方法 private void Button1_Click (object sender, System.EventArgs e) { Server.Transfer("anotherwebform.aspx"); }      目标页面代码: private void Page_Load (object sender, System.EventArgs e) {   WebForm1 wf1; wf1=(WebForm1)Context.Handler; Label1.Text=wf1.Name;  }  95、一列数的规则如下: 1、1、2、3、5、8、13、21、34......   求第30位数是多少, 用递归算法实现。 答:public class MainClass        {            public static void Main()              {                Console.WriteLine(Foo(30));            }            public static int Foo(int i)            {                if (i <= 0)                    return 0;                else if(i > 0 && i <= 2)                    return 1;                else return Foo(i -1) + Foo(i - 2);            }        }   96、override与重载的区别  答:  override 与重载的区别。重载是方法的名称相同。参数或参数类型不同,进行多次重载以适应不同的需要  Override 是进行基类中函数的重写。为了适应需要。 97、请编程遍历页面上所有TextBox控件并给它赋值为string.Empty?  答:         foreach (System.Windows.Forms.Control control in this.Controls)         {  if (control is System.Windows.Forms.TextBox)  {       System.Windows.Forms.TextBox tb = (System.Windows.Forms.TextBox)control ;       tb.Text = String.Empty ;  }         } 98、请编程实现一个冒泡排序算法?  答:  int [] array = new int [*] ;  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 ;  }  }  } 99、描述一下C#中索引器的实现过程,是否只能根据数字进行索引?  答:不是。可以用任意类型。 100、net中读写数据库需要用到那些类?他们的作用?  答:DataSet:数据存储器。       DataCommand:执行语句命令。       DataAdapter:数据的集合,用于填充。 101、ASP.net的身份验证方式有哪些?分别是什么原理?  答:Windwos(默认)用IIS...      From(窗体)用帐户      Passport(密钥) 102、在.net中,配件的意思是?  答:程序集。(中间语言,源数据,资源,装配清单) 103、net Remoting 的工作原理是什么?  答:服务器端向客户端发送一个进程编号,一个程序域编号,以确定对象的位置 104、根据线程安全的相关知识,分析以下代码,当调用test方法时i>10时是否会引起死锁?并简要说明理由。  public void test(int i)   {       lock(this)   {       if (i>10)       {         i--;         test(i);       }   }   }  答:不会发生死锁,(但有一点int是按值传递的,所以每次改变的都只是一个副本,因此不会出现死锁。但如果把int换做一个object,那么死锁会发生) 106、简要谈一下您对微软.NET 构架下remoting和webservice两项技术的理解以及实际中的应用。 答:WS主要是可利用HTTP穿透防火墙。Remoting可以利用TCP/IP,二进制传送提高效率 107、用C#实现以下功能 a 产生一个int数组,长度为100,并向其中随机插入1-100,并且不能重复 答 :List L=new List();  Random random = new Random();  for (int i = 1; i <= 100; i++)  {  if (L.IndexOf(i) < 0)  {  L.Add(random.Next(1,100));  }  }   b 对上面生成的数组排序,需要支持升序、降序两种顺序  答   L.Reverse(L);       L.Sort(L);   108、请说明.net中的错误处理机制,并举例 答   异常是从 Exception 类类继承的对象。异常从发生问题的代码区域引发,然后沿堆栈向上传递,直到应用程序处理它或程序终止。  try  { //执行代码,不确定是否会出错 }  catch  { //出错处理 }  finally  { //无论怎样,都要执行 } 109、请说出强名的含义  答垃圾回收的原理是根据是否空引用,和该数据类型占用内存来判断该收回多少内存.强类型说白就是必须要有个数据类型. 110、请列出c#中几种循环的方法,并指出他们的不同  答   FOR   WHILE     foreach   do while 111、请指出GAC的含义  答   全局访问缓存 112、SQL SREVER中,向一个表中插入了新数据,如何快捷的得到自增量字段的当前值  答    INSERT INTO jobs (job_desc,min_lvl,max_lvl)        VALUES ('Accountant',12,125)  113、什么是WEB
/
本文档为【.NET绝版面试题】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。

历史搜索

    清空历史搜索