一、@page指令只能在_aspx___文件(填写扩展名)中使用,而@Control指令只能用在_ascx___文件(填写扩展名)中使用.
二、说明控件DataGrid,DataTable,DataView,DetailsView,formView,Repeator经常使用属性,若是要想把一条记录分红两列显示,以上控件哪些能够用,哪些不能够用?若是可用,如何处理?
答:DataMember:绑定的表或者视图,DataSourseID:数据源控制的ID,Visible:是否显示该控件. FormView,Repeator能够用,其余的控件不能可用,在ItemTemplate模板里用表格或者用列表来显示.
三、写出下列的含义 <% %>,<%# %>,
答:<% %>是服务器端代码块
<%# %>表示绑定的数据源
四、请解释Page.IsPostBack,Response.Write,Response.End,DBNull.Value, DataSet,DataTable,DataView,SqlDataReader,stringbuilder,ArrayList?
Page.IsPostBack:是否正是被首次加载
Response.Write:打印指定的文本
Response.End:中止当前的程序并返回结果
DBNull是一个类。DBNull.Value是它惟一的实例。它指数据库中数据为空(<NULL>)时,在.net中的值。
DataSet:DataSet是数据在内存中的表示形式,是不依赖与数据库的独立数据集合.
DataTable:是一个包含列和行表.
DataView:数据视图
SqlDataReader:提供一种从 SQL Server 数据库读取行的只进流的方式。
五、 stringbuilder:StringBuffer线程安全的可变字符序列。一个相似于 String 的字符串缓冲区,但不能修改。虽然在任意时间点上它都包含某种特定的字符序列,但经过某些方法调用能够改变该序列的长度和内容。
ArrayList:动态加载的数组
partial,protected,private,public的含义:
答:partial:仅所属类的成员才能够访问
protected:可被所属的类或派生自所属类的类型访问
public:访问不受限制。
六、如何理解死锁的概念?死锁是如何造成的?在应用中应注意什么事项避免死锁?
死锁是一种条件,不只仅是在关系数据库管理系统 (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
七、什么是事务? 使用事务的语句有哪些?
答:事务是一种机制,是一个操做序列,它包括了一组数据库操做命令,而且全部的命令做为一个总体向
系统提交或者撤消操做请求,要么所有,要么所有不执行.
begin transaction
commit transaction
rollback transaction
八、在update触发器中如何使用修改前,后的数据?
if update(字段1)
begin
...
end
九、有一职员表,字段有工卡和姓名,写出全部姓名重复的职员信息的SQL
语句。
答:select * from test where name in(
select name from test group by name having count(name)>1)
十、有两张表Table1,Table2 ,都只有一个字段。Table有数据'1','2','3','4',Table2有'1','3'.写出一句通用Sql语句将表Table1的记录同步到Table2中!。
答: insert table2 (字段) select '2' union select '4';
十一、请谈谈你对OOP的理解。
面向对象编程(Object Oriented Programming,OOP,面向对象程序设计)是一种计算机编程架构。OOP 的一条基本原则是计算机程序是由单个可以起到子程序做用的单元或对象组合而成。OOP 达到了软件工程的三个主要目标:重用性、灵活性和扩展性。为了实现总体运算,每一个对象都可以接收信息、处理数据和向其它对象发送信息。OOP 主要有如下的概念和组件:
组件 -数据和功能一块儿在运行着的计算机程序中造成的单元,组件在 OOP 计算机程序中是模块和结构化的基础。
抽象性 -程序有能力忽略正在处理中信息的某些方面,即对信息主要方面关注的能力。
封装 -也叫作信息封装:确保组件不会以不可预期的方式改变其它组件的内部状态;只有在那些提供了内部状态改变方法的组件中,才能够访问其内部状态。每类组件都提供了一个与其它组件联系的接口,并规定了其它组件进行调用的方法。
多态性 -组件的引用和类集会涉及到其它许多不一样类型的组件,并且引用组件所产生的结果得依据实际调用的类型。
继承性 - 容许在现存的组件基础上建立子类组件,这统一并加强了多态性和封装性。典型地来讲就是用类来对组件进行分组,并且还能够定义新类为现存的类的扩展,这样就能够将类组织成树形或网状结构,这体现了动做的通用性。
十二、 简述 private、 protected、 public、 internal 修饰符的访问权限。
private : 私有成员, 在类的内部才能够访问。protected : 保护成员,该类内部和继承类中能够访问。public : 公共成员,彻底公开,没有访问限制。internal: 在同一命名空间内能够访问。
1三、 写出一条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
1四、列举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参数简单,显示于地址栏,长度有限
数据库稳定,安全,但性能相对弱
1五、override与重载的区别
Override用来重写父类的方法,重载使用相同名的方法或操做符拥有不一样类型的参数,重写是子类的方法覆盖父类的方法,要求方法名和参数都相同 ,重载是在同一个类中的两个或两个以上的方法,拥有相同的方法名,可是参数却不相同,方法体也不相同,最多见的重载的例子就是类的构造函数
1六、.net的错误处理机制是什么
.net错误处理机制采用try->catch->finally结构,发生错误时,层层上抛,直到找到匹配的Catch为止。
1七、C#中接口和类的异同
接口和类都是类,不一样的是,接口只包含方法或属性的声明,不包含具体实现方法的代码,接口能够实现多继承,而类只能是单继承,继承接口的类必须实现接口中声明的方法或属性。接口主要定义一种规范,统一调用方法,在大型项目中接口正发挥日益重要的做用。
1八、DataReader和DataSet的异同
DataReader和DataSet最大的区别在于,DataReader使用时始终占用SqlConnection,在线操做数据库..任何对SqlConnection的操做都会引起DataReader的异常..由于DataReader每次只在内存中加载一条数据,因此占用的内存是很小的..由于DataReader的特殊性和高性能.因此DataReader是只进的..你读了第一条后就不能再去读取第一条了..
DataSet则是将数据一次性加载在内存中.抛弃数据库链接..读取完毕即放弃数据库链接..由于DataSet将数据所有加载在内存中.因此比较消耗内存...可是确比DataReader要灵活..能够动态的添加行,列,数据.对数据库进行回传更新操做...
1九、 在c#中using和new这两个关键字有什么意义,请写出你所知道的意义?
Using 引入一个名子空间,或在使用了一个对像后自动调用其IDespose,New 实例化一个对像,或修饰一个方法,表此方法彻底重写此方法
20、谈谈类和结构的区别?
最大区别一个是引用类型,一个是值类型 默认成员访问为public是另一个区别
2一、 在.net(C# or vb.net)中如何得到当前窗体或控件的句柄,特别是控件自己的句柄(请列举)。
this(C#) Me(vb.net).
2二、在.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;
}
}
2三、 在.net(C# or vb.net)如何启动另外一个程序。process
2四、 在.net(C# or vb.net)中如何取消一个窗体的关闭
private void Form1_Closing(object sender, System.ComponentModel.CancelEventArgs e)
{
e.Cancel=true;
}
2五、 在.net(C# or vb.net)中,Appplication.Exit 仍是 Form.Close有什么不一样?
答案:一个是退出整个应用程序,一个是关闭其中一个form
2七、在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);
2八、 62-63=1 等式不成立,请移动一个数字(不能够移动减号和等于号),使得等式成立,如何移动?
答案:62移动成2的6次方
2九、new有几种用法
第一种:new Class();
第二种:覆盖方法
public new XXXX(){}
第三种:new 约束指定泛型类声明中的任何类型参数都必须有公共的无参数构造函数。
30、如何把一个array复制到arrayList里
foreach( object o in array )arrayList.Add(o);
3一、datagrid.datasouse能够链接什么数据源 [dataset,datatable,dataview]
dataset,datatable,dataview , IList
3二、概述反射和序列化
反射:程序集包含模块,而模块包含类型,类型又包含成员。反射则提供了封装程序集、模块和类型的对象。您能够使用反射动态地建立类型的实例,将类型绑定到现有对象,或从现有对象中获取类型。而后,能够调用类型的方法或访问其字段和属性
序列化:序列化是将对象转换为容易传输的格式的过程。例如,能够序列化一个对象,而后使用 HTTP 经过 Internet 在客户端和服务器之间传输该对象。在另外一端,反序列化将从该流从新构造对象。
3三、概述o/r mapping 的原理
利用反射,配置 将类于数据库表映射
3四、用sealed修饰的类有什么特色
sealed 修饰符用于防止从所修饰的类派生出其它类。若是一个密封类被指定为其它类的基类,则会发生编译时错误。
密封类不能同时为抽象类。
sealed 修饰符主要用于防止非有意的派生,可是它还能促使某些运行时优化。具体说来,因为密封类永远不会有任何派生类,因此对密封类的实例的虚拟函数成员的调用能够转换为非虚拟调用来处理。
3五、详述.NET里class和struct的异同!
class:放在 ? struct放在?
struct值传递
类与结构有不少类似之处:结构能够实现接口,而且能够具备与类相同的成员类型。然而,结构在几个重要方面不一样于类:结构为值类型而不是引用类型,而且结构不支持继承。结构的值存储在“在堆栈上”或“内联”。细心的程序员有时能够经过聪明地使用结构来加强性能。
3六、概述.NET里对 remoting 和 webservice 两项技术的理解和实际中的应用。
远程逻辑调用,remoing接口只能用在.net中
3七、什么是code-behind技术 aspx and cs
3八、概述三层结构体系 web/business/dataaccess
3九、asp.net如何实现MVC模式,举例说明! web/business/dataaccess
40、什么是ASP.net中的用户控件
答:用户控件就是.ascx扩展名的东西喽,能够拖到不一样的页面中调用,以节省代码.好比登录可能在多个页面上有,就能够作成用户控件,可是有一个问题就是用户控件拖到不一样级别的目录下后里面的图片等的相对路径会变得不许确,须要自已写方法调整.
4一、什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS、CLS和CLR分别做何解释?
答:装箱就是把值类型转成引用类型,从MS IL角度看好像是boxing,没记错的话是把值从堆栈转到堆中.拆箱相反,重载就是指一个方法名同,参数个数不一样,返回值能够相同的方法. CLR(公用语言运行时) CLS(共语言规范) CTS(通用类型系统)
4二、列举一下你所了解的XML技术及其应用
答:XML但是好东西,保存配置,站与站之间的交流,WEB SERVICE都要用它.
4三、值类型和引用类型的区别?写出C#的样例代码。
答:结构是值类型,类是引用类型,因此传结构就是值类型的应用啦,传对象或类就是引用类型的,这个不用多写了吧.
4四、ADO.net中经常使用的对象有哪些?分别描述一下。
答:connection command sqladapter dataset datatable dataview等等.写不完了.
4五、如何理解委托?
答:听说至关于函数指针,定义了委托就能够在不调用原方法名称的状况下调用那个方法.
msdn2005中是这样解释的:
委托具备如下特色:
委托相似于 C++ 函数指针,但它是类型安全的。
委托容许将方法做为参数进行传递。
委托可用于定义回调方法。
委托能够连接在一块儿;例如,能够对一个事件调用多个方法。
方法不须要与委托签名精确匹配。有关更多信息,请参见协变和逆变。
C# 2.0 版引入了匿名方法的概念,此类方法容许将代码块做为参数传递,以代替单独定义的方法。
4六、C#中的接口和类有什么异同。
答:接口是负责功能的定义,项目中经过接口来规范类,操做类以及抽象类的概念!
而类是负责功能的具体实现!
在类中也有抽象类的定义,抽象类与接口的区别在于:
抽象类是一个不彻底的类,类里面有抽象的方法,属性,也能够有具体的方法和属性,须要进一步的专业化。
但接口是一个行为的规范,里面的全部东西都是抽象的!
一个类只能够继承一个基类也就是父类,但能够实现多个接口
4七、.net中读写数据库须要用到哪些类?他们的做用
答:这个类自已能够写的啊,你是指基类吗?那configuration,sqlconnection,sqlcommand等都要用到.
4八、UDP链接和TCP链接的异同。
答:前者只管传,无论数据到不到,无须创建链接.后者保证传输的数据准确,需要连结.
4九、ASP.net的身份验证方式有哪些?分别是什么原理?
答:form认证,windows集成认证等,原理不清楚.
50、什么是code-Behind技术。
答:代码分离,这是个明智的东西,像ASP这样混成一堆很不爽.或者能够理解成HTML代码写在前台,C#代码写在后台.固然前台也有脚本,类的调用等,其实写在一块儿也是能够的.
5一、.net中读写XML的类都归属于哪些命名空间?
答:System.Xml
5二、解释一下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和提供的调用接口,包含一组端口元素
5三、.什么是SOAP,有哪些应用。
答:SOAP(Simple Object Access Protocol )简单对象访问协议是在分散或分布式的环境中交换信息并执行远程过程调用的协议,是一个基于XML的协议。使用SOAP,不用考虑任何特定的传输协议(最经常使用的仍是HTTP协议),能够容许任何类型的对象或代码,在任何平台上,以任何一直语言相互通讯。这种相互通讯采用的是XML格式的消息,具体请看:http://playist.blogchina.com/2521621.html
5四、经常使用的调用webservice方法有哪些?
答:
能够从浏览器、ASP页或其余WEB服务调用能够使用HTTP-GET HTTP-POST访问WEB服务也能够从ASP页或其余WEB服务向其余WEB服务发出SOAP请求HTTP-GET HTTP-POST SOAP 使用WEB服务代理
5五、 私有程序集与共享程序集有什么区别?
一个私有程序集一般为单个应用程序所使用,而且存储于这个应用程序所在的目录之中,或此目录下面的一个子目录中。共享程序集一般存储在全局程序集缓存(Global Assembly Cache)之中,这是一个由.NET运行时所维护的程序集仓库。共享程序集一般是对许多应用程序都有用的代码库,好比.NET Framework类。
5六、 请解释进程与线程的区别?进程与程序的区别?
通常,一个应用程序对应于一个或多个进程,能够把进程看做是该应用程序在*做系统中的标识;而一个进程一般由多个线程组成,而线程是*做系统为该应用程序分配处理时间的最小单元。
5七、 CLR与IL分别是什么含义?
CLR:公共语言运行时,相似于Java中的JVM,Java虚拟机;在.Net环境下,各类编程语言使用一种共同的基础资源环境,这就是CLR,CLR将直接与*做系统进行通讯,而编程语言如C#.NET将尽可能避免直接与*做系统直接通讯,增强了程序代码的执行安全性,能够这样看:CLR就是具体的编程语言如:C#.NET与*做系统之间的翻译,同时它为具体的编程语言提供了许多资源:
IL,中间语言,也称MSIL,微软中间语言,或CIL,通用中间语言;全部.NET源代码(无论用哪一种语言编写)在进行编译时都被编译成IL。在应用程序运行时被即时(Just-In-Time,JIT)编译器处理成为机器码,被解释及执行。
5八、请解释ASP。NET中以什么方式进行数据验证
Aps.net 中有非空验证,比较验证,取值范围验证,正则表达式验证及客户自定义验证五大控件,另还有一个集中验证信息处理控件
11. WEB控件能够激发服务端事件,请谈谈服务端事件是怎么发生并解释其原理?自动传回是什么?为何要使用自动传回。
在web控件发生事件时,客户端采用提交的形式将数据交回服务端,服务端先调用Page_Load事件,而后根据传回的状态信息自动调用服务端事件自动传回是当咱们在点击客户端控件时,采用提交表单的形式将数据直接传回到务端
只有经过自动传回才能实现服务端事件的机制,若是没有自动回传机制就只能调用客户端事件,而不能调用服务端事件
5九、WEB控件及HTML服务端控件可否调用客户端方法?若是能,请解释如何调用?
能够调用
例如:<asp:TextBox id="TextBox1" onclick="clientfunction();" runat="server">
</asp:TextBox>
<INPUT id="Button2" value="Button" name="Button2"
runat="server" onclick="clientfunction();">
60、 请解释web.config文件中的重要节点
appSettings包含自定义应用程序设置。
system.web 系统配置
compilation动态调试编译设置
customErrors自定义错误信息设置
authentication身份验证,此节设置应用程序的身份验证策略。
authorization受权, 此节设置应用程序的受权策略.
6一、 请解释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" 表用运行时使用哪个隐藏类
6二、 什么是viewstate,可否禁用?是否所用控件均可以禁用?
Viewstate是保存状态的一种机制,EnableViewState属性设置为false便可禁用
6三、 当发现不能读取页面上的输入的数据时颇有多是什么缘由形成的?怎么解决
颇有多是在Page_Load中数据处理时没有进行Page的IsPostBack属性判断
6四、 请解释什么是上下文对象,在什么状况下要使用上下文对象
上下文对象是指HttpContext类的Current 属性,当咱们在一个普通类中要访问内置对象(Response,Request,Session,Server,Appliction等)时就要以使用此对象
6五、 请解释转发与跳转的区别?
转发就是服务端的跳转A页面提交数据到B页面,B页面进行处理而后从服务端跳转到其它页面
跳转就是指客户端的跳转
6六、请说明在.net中经常使用的几种页面间传递参数的方法,并说出他们的优缺点。
session(viewstate) 简单,但易丢失application 全局cookie 简单,但可能不支持,可能被伪造
input ttype="hidden" 简单,可能被伪造url参数简单,显示于地址栏,长度有限,数据库稳定,安全,但性能相对弱
6七、DataReader和DataSet的异同
DataReader和DataSet最大的区别在于,DataReader使用时始终占用SqlConnection,在线操做数据库..任何对SqlConnection的操做都会引起DataReader的异常..由于DataReader每次只在内存中加载一条数据,因此占用的内存是很小的..由于DataReader的特殊性和高性能.因此DataReader是只进的..你读了第一条后就不能再去读取第一条了..
DataSet则是将数据一次性加载在内存中.抛弃数据库链接..读取完毕即放弃数据库链接..由于DataSet将数据所有加载在内存中.因此比较消耗内存...可是确比DataReader要灵活..能够动态的添加行,列,数据.对数据库进行回传更新操做...
6八、谈谈类和结构的区别?
最大区别一个是引用类型,一个是值类型默认成员访问为public是另一个区别都要用到.
6九、 请解释什么是上下文对象,在什么状况下要使用上下文对象
上下文对象是指HttpContext类的Current 属性,当咱们在一个普通类中要访问内置对象(Response,Request,Session,Server,Appliction等)时就要以使用此对象
70、请简述一下用Socket进行同步通信编程的详细步骤
一、在应用程序和远程设备中使用协议和网络地址初始化套接字
二、在应用程序中经过指定端口和地址创建监听
三、远程设备发出链接请求
四、应用程序接受链接产生通讯scoket
五、应用程序和远程设备开始通信(在通信中应用程序将挂起直到通信结束)
六、通信结束,关闭应用程序和远程设备的Socket回收资源
7一、在C#中,string str = null 与 string str = “” 请尽可能使用文字或图象说明其中的区别。
string str = null 是不给他分配内存空间,而string str = “”给它分配长度为空字符窜的内存空间.
7二、请详述在dotnet中类(class)与结构(struct)的异同:(10分)
Class能够被实例化,属于引用类型,是分配在内存的堆上的,Struct属于值类型,是分配在内存的栈上的.
7三、SQLSERVER服务器中,给定表 table1 中有两个字段 ID、LastUpdateDate,ID表示更新的事务号, LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句得到最后更新的事务号。(10)
select top ID from table1 order by LastUpdateData desc
7四、简要谈一下您对微软.NET 构架下remoting和webservice两项技术的理解以及实际中的应用。(10)
remoting是.net 中用来跨越machine, process, appdomain 进行方法调用的技术,对于三成结构的程序,就能够使用remoting技术来构建.它是分布应用的基础技术.至关于之前的DCOM Web Service是一种构建应用程序的普通模型,并能在全部支持internet网通信的操做系统上实施。Web Service令基于组件的开发和web的结合达到最佳,基于组件的对象模型
7五、什么叫作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 的列时发生语法错误。
7六、 产生一个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];
7七、请叙述类与结构的区别。
1)、结构是值类型;
2)、结构不支持继承;
3)、结构不能定义默认的构造函数;
4)、结构不能定义析构函数;
5)、结构不能使用初始值设置域值。
7八、维护数据库的完整性、一致性、你喜欢用触发器仍是自写业务逻辑?为何
答:尽量用约束(包括CHECK、主键、惟一键、外键、非空字段)实现,这种方式的效率最好;其次用触发器,这种方式能够保证不管何种业务系统访问数据库都能维持数据库的完整性、一致性;最后再考虑用自写业务逻辑实现,但这种方式效率最低、编程最复杂,当为下下之策
7九、 ADO。NET相对于ADO等主要有什么改进?
答 ADO数据以Recordset 形式存储 ADO.NET以DataSet形式存储
Recordset对数据库持续链接访问ADO.NET提供对数据库断开链接
ADO.NET与ADO相比,优点在于提供了数据集和数据适配器,有利于实现分布式处理,下降对数据库服务器资源的消耗。
80、 ASP。NET与ASP相比,主要有哪些进步?
答 asp.net 能够使用强类型语言
页面是编译,执行速度快, 增长安全性和可靠性
,经过继承机制来支持代码的重用,提供声明性服务器控件减小代码行数
Asp须要解释,执行速度慢,重用代码不方便,没有调试机制
8一、C#中的委托是什么?事件是否是一种委托?
答 委托本质上是一种“方法接口”,它至关于C/C++中的函数指针,固然它比函数指针安全,在C#中一般用于事件处理。与JAVA相比,能够避免使用大量小粒度的匿名类。(不过,也许微软就是使用相似于JAVA的匿名类实现委托的,只不过从字面上看起不是那么回事罢了,谁知道呢?)
事件不是委托,不过因为事件的性质决定了处理它的程序逻辑能访问的参数,所以,在C#中处理事件的逻辑都包装为委托(一种“方法接口”)。实际上,若是你处理自定义的事件,就像JAVA中那样用接口实现也是能够的,不过这么作在C#通常没有什么特别的好处。
8二、datagrid.datasouse能够链接什么数据源
答 [dataset,datatable,dataview] dataset,datatable,dataview , IList
8三、用sealed修饰的类有什么特色
答 sealed 修饰符用于防止从所修饰的类派生出其它类。若是一个密封类被指定为其余类的基类,则会发生编译时错误。密封类不能同时为抽象类。
sealed 修饰符主要用于防止非有意的派生,可是它还能促使某些运行时优化。具体说来,因为密封类永远不会有任何派生类,因此对密封类的实例的虚拟函数成员的调用能够转换为非虚拟调用来处理。
8四、用.net作B/S结构的系统,您是用几层结构来开发,每一层之间的关系以及为何要这样分层?
答:通常为3层
数据访问层,业务层,表示层。
数据访问层对数据库进行增删查改。
业务层通常分为二层,业务表观层实现与表示层的沟通,业务规则层实现用户密码的安全等。
表示层为了与用户交互例如用户添加表单。
优势: 分工明确,条理清晰,易于调试,并且具备可扩展性。
缺点: 增长成本。
8五、什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS、CLS和CLR分别做何解释?
答 应用程序域能够理解为一种轻量级进程。起到安全的做用。占用资源小
受管制的代码:unsafe:非托管代码。不通过CLR运行。
强类型系统 RTTI:类型识别系统。
装箱就是把值类型到引用类型的转换
拆箱就是引用类型到值类型的转换
重载 方法名相同 不用个数的参数或者指定不一样参数类型
CTS:通用语言系统。CLS:通用语言规范。CLR:公共语言运行库。
8六、ADO.net中经常使用的对象有哪些?分别描述一下。
答:Connection 对象用于在应用程序和数据库之间的链接
Command 能够检索和操纵数据库中的数据
DataAdapter对象充当DataSet和数据源之间用于检索和保存数据的桥接器
DataSet 对象从数据库检索的数据能够存储在其中可以以XML形式保存
DataReader 是查询结果的一种只进。只读的视图 不具备DataSet的任何复杂功能
因此能够加快访问和查看数据的速度 不提供断开式访问
8七、如何理解委托?
答:听说至关于函数指针,定义了委托就能够在不调用原方法名称的状况下调用那个方法.
msdn2005中是这样解释的:
委托具备如下特色:委托相似于 C++ 函数指针,但它是类型安全的。
委托容许将方法做为参数进行传递。委托可用于定义回调方法
委托能够连接在一块儿;例如,能够对一个事件调用多个方法。
方法不须要与委托签名精确匹配。
8八、C#中的委托是什么?事件是否是一种委托?
答 委托能够把一个方法做为参数代入另外一个方法。
委托能够理解为指向一个函数的引用。
是,是一种特殊的委托
8九、进程和线程分别怎么理解?
答:进程是老子,线程是儿子,没有老子就没有儿子,一个老子能够有多个儿子.一个儿子能够成为别人的儿子,一个老子也能够为别的老子生儿子.
90、解释一下UDDI、WSDL的意义及其做用
答:UDDI 用于注册各个服务提供商提供的服务 以即可以共享它们它还有助于WEB服务客户或web用户查找该Web服务
wsdl 是web服务描述语言(web Services Description Language)
9一、什么是SOAP,有哪些应用。
答:SOAP(Simple Object Access Protocol )简单对象访问协议是在分散或分布式的环境中交换信息并执行远程过程调用的协议,是一个基于XML的协议。使用SOAP,不用考虑任何特定的传输协议(最经常使用的仍是HTTP协议),能够容许任何类型的对象或代码,在任何平台上,以任何一直语言相互通讯。这种相互通讯采用的是XML格式的消息,具体请看
9二、 概述.NET里对 remoting 和 webservice 两项技术的理解和实际中的应用。
答 远程逻辑调用,remoing接口只能用在.net中
9三、 简述 private、 protected、 public、 internal 修饰符的访问权限。
答 private : 私有成员, 在类的内部才能够访问。
protected : 保护成员,该类内部和继承类中能够访问。
public : 公共成员,彻底公开,没有访问限制。
internal: 在同一命名空间内能够访问。
9四、列举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;
}
9五、一列数的规则以下: 一、一、二、三、五、八、1三、2一、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);
}
}
9六、override与重载的区别
答:
override 与重载的区别。重载是方法的名称相同。参数或参数类型不一样,进行屡次重载以适应不一样的须要
Override 是进行基类中函数的重写。为了适应须要。
9七、请编程遍历页面上全部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 ;
}
}
9八、请编程实现一个冒泡排序算法?
答:
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 ;
}
}
}
9九、描述一下C#中索引器的实现过程,是否只能根据数字进行索引?
答:不是。能够用任意类型。
100、net中读写数据库须要用到那些类?他们的做用?
答:DataSet:数据存储器。
DataCommand:执行语句命令。
DataAdapter:数据的集合,用于填充。
10一、ASP.net的身份验证方式有哪些?分别是什么原理?
答:Windwos(默认)用IIS...
From(窗体)用账户
Passport(密钥)
10二、在.net中,配件的意思是?
答:程序集。(中间语言,源数据,资源,装配清单)
10三、net Remoting 的工做原理是什么?
答:服务器端向客户端发送一个进程编号,一个程序域编号,以肯定对象的位置
10四、根据线程安全的相关知识,分析如下代码,当调用test方法时i>10时是否会引发死锁?并简要说明理由。
public void test(int i)
{
lock(this)
{
if (i>10)
{
i--;
test(i);
}
}
}
答:不会发生死锁,(但有一点int是按值传递的,因此每次改变的都只是一个副本,所以不会出现死锁。但若是把int换作一个object,那么死锁会发生)
10六、简要谈一下您对微软.NET 构架下remoting和webservice两项技术的理解以及实际中的应用。
答:WS主要是可利用HTTP穿透防火墙。Remoting能够利用TCP/IP,二进制传送提升效率
10七、用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);
10八、请说明.net中的错误处理机制,并举例
答 异常是从 Exception 类类继承的对象。异常从发生问题的代码区域引起,而后沿堆栈向上传递,直到应用程序处理它或程序终止。
try
{ //执行代码,不肯定是否会出错 }
catch
{ //出错处理 }
finally
{ //不管怎样,都要执行 }
10九、请说出强名的含义
答垃圾回收的原理是根据是否空引用,和该数据类型占用内存来判断该收回多少内存.强类型说白就是必需要有个数据类型.
1十、请列出c#中几种循环的方法,并指出他们的不一样
答 FOR WHILE foreach do while
1十一、请指出GAC的含义
答 全局访问缓存
1十二、SQL SREVER中,向一个表中插入了新数据,如何快捷的获得自增量字段的当前值
答 INSERT INTO jobs (job_desc,min_lvl,max_lvl)
VALUES ('Accountant',12,125)
11三、什么是WEB控件?使用WEB控件有那些优点?
答 web控件就是能够在服务器执行的控件,优点在于能够回传数据,带有事件驱动
11四、 请解释ASP。NET中以什么方式进行数据验证?
答 .net中提供了几个数据验证控件,能够在服务器端或者客户端进行验证。
11五、请谈谈对正则表达式的见解?
答: 主要用在字符串的匹配上面,与具体的语言环境无关。
11六、 ASP。NET中共有几种类型的控件?各有什么区别?
答 Html 控件 传统的html标记
Web 控件 能够回传数据,事件驱动
自定义 控件 在原有控件的基础上增长功能
复合控件 多个子控件复合成一个新的控件
11七、 WEB控件能够激法服务端事件,请谈谈服务端事件是怎么发生并解释其原理?自动传回是什么?为何要使用自动传回。
答 经过实现IPostBack这个接口来执行事件。自动回传就是AutoPostBack,使用自动回传能够监视客户端变化状况并将这种改变返回到服务器端
11八、 WEB控件及HTML服务端控件可否调用客户端方法?若是能,请解释如何调用?
答 能,服务器端控件在html中表现形式仍是html标记,因此能够执行客户端事件,有多种方式:一、control.Attributes["onclick"]="...;";
二、<script for="controlName" event="onclick"></script>
11九、什么是viewstate,可否禁用?是否所用控件均可以禁用?
答 能够所有禁用,viewstate就是hidden input,只不过加上了微软的编码方式记录控件的状态
120、 当发现不能读取页面上的输入的数据时颇有多是什么缘由形成的?怎么解决
答 可能就是事件没有关联,或者根本就没有写读取代码。
解决 检查代码, 设断点调试
12一、请解释一个WEB页面中代码执行次序。
答 参看.cs 知道最早执行OnInit(); 而后到Page_Load,最后到具体的执行事件。
12二、请解释什么是上下文对象,在什么状况下要使用上下文对象
答 HttpContext, 在类中调用的时候须要用到HttpContext
12三、请解释转发与跳转的区别?
答 Transfer 是转发 包括HttpHandler对象
Redirect 就是跳转
Server.Transfer(ASP 3.0 以上) 和 Response.Redirect 在之前的 ASP 中就存在了,Page.Navigate 是 ASP.NET Beta 1 提供的新功能,它们之间的区别在于:
一、 Server.Transfer - 用于把处理的控制权从一个页面转移到另外一个页面,在转移的过程当中,没有离开服务器,内部控件(如:request, session 等)的保存的信息不变,所以,你能从页面 A 跳到页面 B 而不会丢失页面 A 中收集的用户提交信息。此外,在转移的过程当中,浏览器的 URL 栏不变。
二、Response.Redirect - 发送一个 HTTP 响应到客户端,告诉客户端跳转到一个新的页面,客户端再发送跳转请求到服务器。使用此方法时,将没法保存全部的内部控件数据,页面 A 跳转到页面 B,页面 B 将没法访问页面 A 中 Form 提交的数据。
三、Page.Navigate - Page.Navigate 实现的功能和 Response.Redirect 差很少,它实际上包括三个步骤:首先调用 Response.Redirect,其次依次卸载全部的控件,最后调用 Response.End。
12四、 请解释ASP。NET中button linkbutton imagebutton 及hyperlink这四个控件之间的功别
答 button imagebutton 将数据传递回服务器
hyperlinK 页面之间的导航
linkbutton主要用于将数据保存到服务器或访问服务器上的数据
12五、请解释一下。NET多层应用程序中层与层之间以那几种方式进行数据传递。并解释你本身的项目中采用那种方式进行。
答 这个传递方式不定,不少都是传递DataSet, XML也能够
12六、若是出现ASP。NET中的事件不能触发可能因为什么缘由形成?
答 事件丢失,特别是使用vss的时候最容易形成这种状况,缘由不明
12七、若是须要在datagride控件中的某一列中添加下拉列表框并绑定数据怎么解决?
答 使用模板列来添加dropdownlist,绑定数据使用代码前置的方式
12八、请解释asp.net中的数据绑定与传统数据绑定有什么区别?
答 更灵活 更方便
12九、请解释.net采用委托实现的事件模型与JAVA中采用接口实现的事件模型有什么区别。
答 以图示方式解释。
130、请解释接口的显式实现有什么意义?
答 规定强制执行,保持一致
13一、 什么状况用HTML控件,什么状况用WEB控件,并比较二者差异
答 客户端表现用html控件,若是想和server端交互,那么加上runat=server,它就成了服务器端控件,但它没有web控件的不少方法和属性,若是你须要用到,那么仍是用web controls
13二、用Singleton如何写设计模式
答:static属性里面new ,构造函数private
13三、什么是Application Pool?
答:Web应用,相似Thread Pool,提升并发性能。
13四、什么是虚函数?什么是抽象函数?
答:虚函数:没有实现的,可由子类继承并重写的函数。抽象函数:规定其非虚子类必须实现的函数,必须被重写。
13五、什么是XML?
答:XML便可扩展标记语言。eXtensible Markup Language.标记是指计算机所能理解的信息符号,经过此种标记,计算机之间能够处理包含各类信息的文章等。如何定义这些标记,便可以选择国际通用的标记语言,好比HTML,也能够使用象XML这样由相关人士自由决定的标记语言,这就是语言的可扩展性。XML是从SGML中简化修改出来的。它主要用到的有XML、XSL和XPath等。
13六、什么是Web Service?UDDI?
答:Web Service即是基于网络的、分布式的模块化组件,它执行特定的任务,遵照具体的技术规范,这些规范使得Web Service能与其余兼容的组件进行互操做。
UDDI 的目的是为电子商务创建标准;UDDI是一套基于Web的、分布式的、为Web Service提供的、信息注册中心的实现标准规范,同时也包含一组使企业能将自身提供的Web Service注册,以使别的企业可以发现的访问协议的实现标准。
13七、什么是ASP.net中的用户控件?
答:用户控件通常用在内容多为静态,或者少量会改变的状况下..用的比较大..相似ASP中的include..可是功能要强大的多。
13八、C#中 property 与 attribute的区别,他们各有什么用处,这种机制的好处在哪里?
答:一个是属性,用于存取类的字段,一个是特性,用来标识类,方法等的附加性质
13九、XML 与 HTML 的主要区别
答:1. XML是区分大小写字母的,HTML不区分。
2. 在HTML中,若是上下文清楚地显示出段落或者列表键在何处结尾,那么你能够省略</p>或者</li>之类的结束 标记。在XML中,绝对不能省略掉结束标记。
3. 在XML中,拥有单个标记而没有匹配的结束标记的元素必须用一个 / 字符做为结尾。这样分析器就知道不用 查找结束标记了。
4. 在XML中,属性值必须分装在引号中。在HTML中,引号是可用可不用的。
5. 在HTML中,能够拥有不带值的属性名。在XML中,全部的属性都必须带有相应的值。
140、.在Asp.net中全部的自定义用户控件都必须继承自________?
答:Control。
14二、在.Net中全部可序列化的类都被标记为_____?
答:[serializable]
14三、当类T只声明了私有实例构造函数时,则在T的程序文本外部,___能够___(能够 or 不能够)从T派生出新的类,不能够____(能够 or 不能够)直接建立T的任何实例。
答:不能够,不能够。
14四、 C#中 property 与 attribute的区别,他们各有什么用处,这种机制的好处在哪里?
答:attribute:自定义属性的基类;property :类中的属性
14五、C#能否对内存进行直接的操做?
答:在.net下,.net引用了垃圾回收(GC)功能,它替代了程序员 不过在C#中,不能直接实现Finalize方法,而是在析构函数中调用基类的Finalize()方法
14六、大概描述一下ASP。NET服务器控件的生命周期
答:初始化 加载视图状态 处理回发数据 加载 发送回发更改通知 处理回发事件 预呈现 保存状态 呈现 处置卸载
Anonymous Inner Class (匿名内部类) 是否能够extends(继承)其它类,是否能够implements(实现)interface(接口)?
答:不能,能够实现接口
147.Static Nested Class 和 Inner Class的不一样,说得越多越好
答:Static Nested Class是被声明为静态(static)的内部类,它能够不依赖于外部类实例被实例化。而一般的内部类须要在外部类实例化后才能实例化。
148.,&和&&的区别。
&是位运算符,表示按位与运算,&&是逻辑运算符,表示逻辑与(and).
149.HashMap和Hashtable的区别。
答:HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap容许空(null)键值(key),因为非线程安全,效率上可能高于Hashtable.
150.short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
答:short s1 = 1; s1 = s1 + 1; (s1+1运算结果是int型,须要强制转换类型)
short s1 = 1; s1 += 1;(能够正确编译)
15一、Overloaded的方法是否能够改变返回值的类型?
答:Overloaded的方法是能够改变返回值的类型。
15二、error和exception有什么区别?
答:error 表示恢复不是不可能但很困难的状况下的一种严重问题。好比说内存溢出。不可能期望程序能处理这样的状况。
exception 表示一种设计或实现问题。也就是说,它表示若是程序运行正常,从不会发生的状况。
15三、<%# %> 和 <% %> 有什么区别?
答:<%# %>表示绑定的数据源
<% %>是服务器端代码块
15四、你以为ASP.NET 2.0(VS2005)和你之前使用的开发工具(.Net 1.0或其余)有什么最大的区别?你在之前的平台上使用的哪些开发思想(pattern / architecture)能够移植到ASP.NET 2.0上 (或者已经内嵌在ASP.NET 2.0中)
答:1 ASP.NET 2.0 把一些代码进行了封装打包,因此相比1.0相同功能减小了不少代码.
2 同时支持代码分离和页面嵌入服务器端代码两种模式,之前1.0版本,.NET提示帮助只有在分离的代码文件,无 法 在页面嵌入服务器端代码得到帮助提示,
3 代码和设计界面切换的时候,2.0支持光标定位.这个我比较喜欢
4 在绑定数据,作表的分页.UPDATE,DELETE,等操做均可以可视化操做,方便了初学者
5 在ASP.NET中增长了40多个新的控件,减小了工做量
15五、重载与覆盖的区别?
答:一、方法的覆盖是子类和父类之间的关系,是垂直关系;方法的重载是同一个类中方法之间的关系,是水平关系
二、覆盖只能由一个方法,或只能由一对方法产生关系;方法的重载是多个方法之间的关系。
三、覆盖要求参数列表相同;重载要求参数列表不一样。
四、覆盖关系中,调用那个方法体,是根据对象的类型(对象对应存储空间类型)来决定;重载关系,是根据调 用时的实参表与形参表来选择方法体的。
15六、描述一下C#中索引器的实现过程,是否只能根据数字进行索引?
答:不是。能够用任意类型。
124.SQLSERVER服务器中,给定表 table1 中有两个字段 ID、LastUpdateDate,ID表示更新的事务号, LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句得到最后更新的事务号
答:Select ID FROM table1 Where LastUpdateDate = (Select MAX(LastUpdateDate) FROM table1)
15七、分析如下代码。
public static void test(string ConnectString)
{
System.Data.OleDb.OleDbConnection conn = new System.Data.OleDb.OleDbConnection();
conn.ConnectionString = ConnectString;
try
{
conn.Open();
…….
}
catch(Exception Ex)
{
MessageBox.Show(Ex.ToString());
}
finally
{
if (!conn.State.Equals(ConnectionState.Closed))
conn.Close();
}
}
请问
1)以上代码能够正确使用链接池吗?
答:回答:若是传入的connectionString是如出一辙的话,能够正确使用链接池。不过如出一辙的意思是,连字符的空格数,顺序彻底一致。
2)以上代码所使用的异常处理方法,是否全部在test方法内的异常均可以被捕捉并显示出来?
答:只能够捕捉数据库链接中的异常吧. (finally中,catch中,若是有别的可能引起异常的操做,也应该用try,catch。因此理论上并不是全部异常都会被捕捉。)
15八、公司要求开发一个继承System.Windows.Forms.ListView类的组件,要求达到如下的特殊功能:点击ListView各列列头时,能按照点击列的每行值进行重排视图中的全部行 (排序的方式如DataGrid类似)。根据您的知识,请简要谈一下您的思路:
答:根据点击的列头,包该列的ID取出,按照该ID排序后,在给绑定到ListView中
15九、abstract class和interface有什么区别?
答:声明方法的存在而不去实现它的类被叫作抽象类(abstract class),它用于要建立一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类的状况。不能建立abstract 类的实例。然而能够建立一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态方法。Abstract 类的子类为它们父类中的全部抽象方法提供实现,不然它们也是抽象类为。取而代之,在子类中实现该方法。知道其行为的其它类能够在类中实现这些方法。
接口(interface)是抽象类的变体。在接口中,全部方法都是抽象的。多继承性可经过实现这样的接口而得到。接口中的全部方法都是抽象的,没有一个有程序体。接口只能够定义static final成员变量。接口的实现与子类类似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给予)全部这种接口的方法。而后,它能够在实现了该接口的类的任何对象上调用接口的方法。因为有抽象类,它容许使用接口名做为引用变量的类型。一般的动态联编将生效。引用能够转换到接口类型或从接口类型转换,instanceof 运算符能够用来决定某对象的类是否实现了接口
160、C#中 property 与 attribute的区别,他们各有什么用处,这种机制的好处在哪里?
property和attribute汉语都称之为属性。不过property是指类向外提供的数据区域。而attribute则是描述对象在编译时或运行时属性的。这二者是有本质区别的。
52.sleep() 和 wait() 有什么区别?
答:sleep()方法是使线程中止一段时间的方法。在sleep 时间间隔期满后,线程不必定当即恢复执行。这是由于在那个时刻,其它线程可能正在运行并且没有被调度为放弃执行,除非(a)“醒来”的线程具备更高的优先级
(b)正在运行的线程由于其它缘由而阻塞。
wait()是线程交互时,若是线程对一个同步对象x 发出一个wait()调用,该线程会暂停执行,被调对象进入等待状态,直到被唤醒或等待时间到。
16一、谈谈final, finally, finalize的区别。
答:
final—修饰符(关键字)若是一个类被声明为final,意味着它不能再派生出新的子类,不能做为父类被继承。所以 一个类不能既被声明为 abstract的,又被声明为final的。将变量或方法声明为final,能够保证它们在使用中 不被改变。被声明为final的变量必须在声明时给定初值,而在之后的引用中只能读取,不可修改。被声明为 final的方法也一样只能使用,不能重载
finally—再异常处理时提供 finally 块来执行任何清除操做。若是抛出一个异常,那么相匹配的 catch 子句就会 执行,而后控制就会进入 finally 块(若是有的话)。
finalize—方法名。Java 技术容许使用 finalize() 方法在垃圾收集器将对象从内存中清除出去以前作必要的清理 工做。这个方法是由垃圾收集器在肯定这个对象没有被引用时对这个对象调用的。它是在 Object 类中定义的 ,所以全部的类都继承了它。子类覆盖 finalize() 方法以整理系统资源或者执行其余清理工做。finalize() 方法是在垃圾收集器删除对象以前对这个对象调用的。
16二、如何处理几十万条并发数据?
答:用存储过程或事务。取得最大标识的时候同时更新..注意主键不是自增量方式这种方法并发的时候是不会有重复主键的..取得最大标识要有一个存储过程来获取.
16三、Session有什么重大BUG,微软提出了什么方法加以解决?
答:是iis中因为有进程回收机制,系统繁忙的话Session会丢失,能够用Sate server或SQL Server数据库的方式存储Session不过这种方式比较慢,并且没法捕获Session的END事件。
16四、堆和栈的区别?
答:
栈:由编译器自动分配、释放。在函数体中定义的变量一般在栈上。
堆:通常由程序员分配释放。用new、malloc等分配内存函数分配获得的就是在堆上。
16五、成员变量和成员函数前加static的做用?
答:它们被称为常成员变量和常成员函数,又称为类成员变量和类成员函数。分别用来反映类的状态。好比类成员变量能够用来统计类实例的数量,类成员函数负责这种统计的动做。
16六、启动一个线程是用run()仍是start()?
答:启动一个线程是调用start()方法,使线程所表明的虚拟处理机处于可运行状态,这意味着它能够由JVM调度并执行。这并不意味着线程就会当即运行。run()方法能够产生必须退出的标志来中止一个线程。
16七、接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承实体类(concrete class)?
答:接口能够继承接口。抽象类能够实现(implements)接口,抽象类是否可继承实体类,但前提是实体类必须有明确的构造函数。
16八、构造器Constructor是否可被override?
答:构造器Constructor不能被继承,所以不能重写Overriding,但能够被重载Overloading。
16九、是否能够继承String类?
答:String类是final类故不能够继承。
170、try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,何时被执行,在return前仍是后?
答:会执行,在return前执行。
17一、两个对象值相同(x.equals(y) == true),但却可有不一样的hash code,这句话对不对?
答:不对,有相同的hash code。
17二、swtich是否能做用在byte上,是否能做用在long上,是否能做用在String上?
答:switch(expr1)中,expr1是一个整数表达式。所以传递给 switch 和 case 语句的参数应该是 int、 short、 char 或者 byte。long,string 都不能做用于swtich。
17三、当一个线程进入一个对象的一个synchronized方法后,其它线程是否可进入此对象的其它方法?
不能,一个对象的一个synchronized方法只能由一个线程访问。
17四、abstract的method是否可同时是static,是否可同时是native,是否可同时是synchronized?
答:都不能。
17五、List, Set, Map是否继承自Collection接口?
答:List,Set是Map不是
17六、Set里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用==仍是equals()? 它们有何区别?
答:Set里的元素是不能重复的,那么用iterator()方法来区分重复与否。equals()是判读两个Set是否相等。
equals()和==方法决定引用值是否指向同一对象equals()在类中被覆盖,为的是当两个分离的对象的内容和类型相配的话,返回真值。
17七、数组有没有length()这个方法? String有没有length()这个方法?
答:数组没有length()这个方法,有length的属性。String有有length()这个方法。
ava.lang.StringBuffer线程安全的可变字符序列。一个相似于 String 的字符串缓冲区,但不能修改。虽然在任意时间点上它都包含某种特定的字符序列,但经过某些方法调用能够改变该序列的长度和内容。
17八、String Stringbuffer和StringBuilder的区别?
要谈它们的区别,首先先说说它们之间的相同的地方,首先他们都是存储字符的集合,他们的最大长度是2G,他们在存储字符串数据结构都采用了字符数组,也就是说他们内部都定义了一个字符型数组,用于存储字符串的值。
它们的不一样点有如下几点:
1) 字符型数组固定长度和可变长度的区别:
String型内部定义的数组是固定长度的,一旦使用者给字符串数组对象赋值后,它内部的字符型数组的长度就固定了;
StringBuff型数组内部数组也是固定长度的,可是在运行状态下,它可以本身动态的扩充字符型数组的容量。
2) 效率的区别:
String型数组在全部自身操做,都会比StringBuff效率高。可是若是作多字符串合并的操做时,StringBuff会比String效率高不少。
其缘由就是Stirng每次都是从新建立新的String对象而后进行全字符串拷贝。而StringBuff在没有达到他的容量极限时,它以后进行部分字符串拷贝工做。
例如:String str1=”1234”;
Str1=str1+”5678”;
它要做的工做是,首先从新建立一个str1对象,它的长度是8,而后把”1234”拷贝到新的str1中,而后再把”5678”拷贝到新的str1中,这种对于大字符串操做时效率是很是的底,同时还会出现内存溢出的状况,应为原来的str1垃圾回收器可能没有及时的回收进行内存释放。
例如:StringBuff buff1
Buff1.append(“11111”);
它的操做是,首先判断内部字符型数组对象value的容量是否能装载要合并的字符串,若是能直接将新的字符串“11111”,直接拷贝过来,若是不能也要建立一个新的字符型数组对象,这个字符型数组对象是原来字符型数组对象value长度的两倍,而后把value内容拷贝过来,而后把新的字符串拷贝过来,最后把这个扩容的字符型数组对象赋值给value。
在大容量字符串数组操做时,这个要比String效率高不少。
3)线程安全的。在多线程环境下,对StringBuff对象的操做都是线程安全的,也就是说每一时刻只有一个线程可以处理StringBuff对象。
17九、你在写复杂web界面的时候遇到的最大困难是哪些方面
其实,复杂页面最大的困难并不是如何画出此界面,而是如何让此界面清晰有条理.咱们作页面,并不是仅显示数据,而是要准确/清晰地显示数据,想一想看,若是用户要在此页面中查找一个数据,却杂乱无章,难以查看,你说用户会满意吗?
180、NET里面的datagrid翻页大可能是先把数据读所有取到dataset里面,可是遇到10W条数据以上,这样的翻页事件开销会很大,页面执行起来反映很慢,你有什么好方法解决?
在数据量大的时候,有两个解决办法
1.使用存储过程.而且,并不是由于存储过程比较快的缘由.因为在数据库内部的存储过程,可以实现一些特殊的功能,好比说,能够直接根据当前的排序结果,仅仅取须要的几条数据,如此,不管数据是多少,它仅仅取须要的几条.
2.在实际的操做中,取出的数据,并不是你有10万条,它就会把10万条所有取出来,而是受限于服务器的缓存,其实一次通常仅取1000条左右的记录,不管你数据多少,它仅会一次取这么多出来.因此,配合分页控件,再配合.NET提供的加载N条数据的方法,数据量大的状况下,不见得就会慢.
据我测试,真正慢的,是在取数据总共多少条这个步骤上.此操做在数据少时,没有影响,但在百万条记录以上时,求取数据总数,耗时就会大量增长.因此,大数据量条件下,即不该再显示"共几条/当前第几条"这样的信息.
18一、权限控制方面问题:
从面向对象的角度讲,若是一个程序中,没有应用角色及角色组的话,那么这个程序是不合格的.通常来讲,权限是由权限及流程角色组合而来的,若是仅有权限而没有角色,那么这个控制不灵活;若是仅有角色没有权限,那么这个控制不细致.
固然,用SESSION确定是要的,但这个SESSION,应当只记录当前用户的我的信息,好比他的用户名.在须要判断的时候,根据他的用户名(惟一),至数据库中去取他的权限,或在类中编写权限/角色,根据此用户的用户号及当前模块号,计算当前用户是否对当前页面有操做权限.不过,若是把用户的权限也取出来放在SESSION中的话,这种作法通常仅在很小的网站中使用,稍大一点的系统,基本不容许这么作,并且也作不到html