内容发布更新时间 : 2024/12/24 10:55:35星期一 下面是文章的全部内容请认真阅读。
OnNew( this, e );
4、分析以下代码,完成填空(10分) string strTmp = “abcdefg某某某“;
int i= System.Text.Encoding.Default.GetBytes(strTmp).Length;
int j= strTmp.Length; 以上代码执行完后,i= j= i还真的不知道, j=10
5、SQLSERVER服务器中,给定表 table1 中有两个字段 ID、LastUpdateDate,ID表示更新的事务号, LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号。(10)
select top ID from table1 order by LastUpdateData desc
8、简要谈一下您对微软.NET 构架下remoting和webservice两项技术的理解以及实际中的应用。(10) remoting是.net 中用来跨越machine, process, appdomain 进行方法调用的技术,对于三成结构的程序,就可以使用remoting技术来构建.它是分布应用的基础技术.相当于以前的DCOM Web Service是一种构建应用程序的普通模型,并能在所有支持internet网通讯的操作系统上实施。Web Service令基于组件的开发和web的结合达到最佳,基于组件的对象模型 9.什么叫做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 的列时发生语法错误。
a 产生一个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];
20.请叙述类与结构的区别。 1)、结构是值类型;
2)、结构不支持继承;
3)、结构不能定义默认的构造函数; 4)、结构不能定义析构函数; 5)、结构不能使用初始值设置域值。
======================================================================================================== asp.net面试集合
http://www.cnblogs.com/HappyPrince/archive/2007/03/21/682630.html 1:维护数据库的完整性、一致性、你喜欢用触发器还是自写业务逻辑?为什么
答:尽可能用约束(包括CHECK、主键、唯一键、外键、非空字段)实现,这种方式的效率最好;其次用触发器,这种方式可以保证无论何种业务系统访问数据库都能维持数据库的完整性、一致性;最后再考虑用自写业务逻辑实现,但这种方式效率最低、编程最复杂,当为下下之策 2: ADO。NET相对于ADO等主要有什么改进?
答 ADO数据以Recordset 形式存储 ADO.NET以DataSet形式存储
Recordset对数据库持续连接访问ADO.NET提供对数据库断开连接
ADO.NET与ADO相比,优势在于提供了数据集和数据适配器,有利于实现分布式处理,降低对数据库服务器资源的消耗。
3: ASP。NET与ASP相比,主要有哪些进步?
答 asp.net 可以使用强类型语言
页面是编译,执行速度快, 增加安全性和可靠性,通过继承机制来支持代码的重用,提供声明性服务器控件减少代码行数
Asp需要解释,执行速度慢,重用代码不方便,没有调试机制
4:C#中的委托是什么?事件是不是一种委托?
答 委托本质上是一种“方法接口”,它相当于C/C++中的函数指针,当然它比函数指针安全,在C#中通常用于事件处理。与JAVA相比,可以避免使用大量小粒度的匿名类。(不过,也许微软就是使用类似于JAVA的匿名类实现委托的,只不过从字面上看起不是那么回事罢了,谁知道呢?)
事件不是委托,不过由于事件的性质决定了处理它的程序逻辑能访问的参数,因此,在C#中处理事件的逻辑都包装为委托(一种“方法接口”)。实际上,如果你处理自定义的事件,就像JAVA中那样用接口实现也是可以的,不过这么做在C#一般没有什么特别的好处。 5:new有几种用法 第一种:new Class(); 第二种:覆盖方法
public new XXXX(){}
第三种:new 约束指定泛型类声明中的任何类型参数都必须有公共的无参数构造函数。 6:如何把一个array复制到arrayList里 答 foreach( object o in array )arrayList.Add(o); 7:datagrid.datasouse可以连接什么数据源
答 [dataset,datatable,dataview] dataset,datatable,dataview , IList
8:概述反射和序列化
答 反射:程序集包含模块,而模块包含类型,类型又包含成员。反射则提供了封装程序集、模块和类型的对象。您可以使用反射动态地创建类型的实例,将类型绑定到现有对象,或从现有对象中获取类型。然后,可以调用类型的方法或访问其字段和属性
答 序列化:序列化是将对象转换为容易传输的格式的过程。例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象。在另一端,反序列化将从该流重新构造对象。 9:概述o/r mapping 的原理
答 利用反射,配置 将类于数据库表映射 10:类成员有( )种可访问形式
答 可访问性:public ,protected ,private,internal 11:用sealed修饰的类有什么特点
答 sealed 修饰符用于防止从所修饰的类派生出其它类。如果一个密封类被指定为其他类的基类,则会发生编译时错误。密封类不能同时为抽象类。
sealed 修饰符主要用于防止非有意的派生,但是它还能促使某些运行时优化。具体说来,由于密封类永远不会有任何派生类,所以对密封类的实例的虚拟函数成员的调用可以转换为非虚拟调用来处理。
11:列举ADO.NET中的五个主要对象,并简单描述 connection,command,dataReader,dataAdapter,dataset ... 12:执行下面代码后:
String strTemp =“abcdefg 某某某“;
Int
i
System.Text.Encoding.Default.GetBytes(strTemp).Length; Int j = strTemp.Length; 问:i=(14 ) ;j=(11 )
i=(14 ) ;j=(11 ) 中文两个字节
13:C#中,string str = null 与 string str =““,请尽量用文字说明区别。(要点:说明详细的内存空间分配)
答 string str = null 是不分配内存空间,而string str = ““ 给它分配长度为空字符串的内存空间。
14:概述.NET里对 remoting 和 webservice 两项技术的理解和实际中的应用。
答 远程逻辑调用,remoing接口只能用在.net中 15:什么是code-behind技术 答 aspx and cs 代码隐藏 16:概述三层结构体系 答 表示层 数据层 业务层
17:用.net做B/S结构的系统,您是用几层结构来开发,每一层之间的关系以及为什么要这样分层? 答:一般为3层
数据访问层,业务层,表示层。
数据访问层对数据库进行增删查改。
业务层一般分为二层,业务表观层实现与表示层的沟通,业务规则层实现用户密码的安全等。
表示层为了与用户交互例如用户添加表单。
优点: 分工明确,条理清晰,易于调试,而且具有可扩展性。
缺点: 增加成本。
18:什么是ASP.net中的用户控件
答:用户控件就是.ascx扩展名的东西喽,可以拖到不同的页面中调用,以节省代码.比如登陆可能在多个页面上有,就可以做成用户控件,但是有一个问题就是用户控件拖到不同级别的目录下后里面的图片等的相对路径会变得不准确,需要自已写方法调整.
19:什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS、CLS和CLR分别作何解释?
答 应用程序域可以理解为一种轻量级进程。起到安全的作用。占用资源小
受管制的代码:unsafe:非托管代码。不经过CLR运行。 强类型系统 RTTI:类型识别系统。 装箱就是把值类型到引用类型的转换
拆箱就是引用类型到值类型的转换
重载 方法名相同 不用个数的参数或者指定不同参数类型
CTS:通用语言系统。CLS:通用语言规范。CLR:公共语言运行库。 class box{ int aa(object i) {} object bb() {} }
int bb=5
new box().aa(bb) //装箱 int conver=(int)new box().zz(); //拆箱 //重载
public void aaa(int rad) { }
public void aaa(int len,int bre ) { }
public void aaa(sting str) { }
20:列举一下你所了解的XML技术及其应用
答:xml可以统一数据格式,XML可是好东西,保存配置,站与站之间的交流,WEB SERVICE都要用它.
21 :ADO.net中常用的对象有哪些?分别描述一下。 答:Connection 对象用于在应用程序和数据库之间的连接 Command 可以检索和操纵数据库中的数据
DataAdapter对象充当DataSet和数据源之间用于检索和保存数据的桥接器
DataSet 对象从数据库检索的数据可以存储在其中能够以XML形式保存
DataReader 是查询结果的一种只进。只读的视图 不具有DataSet的任何复杂功能
所以可以加快访问和查看数据的速度 不提供断开式访问
22:如何理解委托?
答:据说相当于函数指针,定义了委托就可以在不调用原方法名称的情况下调用那个方法. msdn2005中是这样解释的:
委托具有以下特点:委托类似于 C++ 函数指针,但它是类型安全的。
委托允许将方法作为参数进行传递。委托可用于定义回调方法
委托可以链接在一起;例如,可以对一个事件调用多个方法。
方法不需要与委托签名精确匹配。
23:C#中的委托是什么?事件是不是一种委托? 答 委托可以把一个方法作为参数代入另一个方法。 委托可以理解为指向一个函数的引用。 是,是一种特殊的委托
24:UDP连接和TCP连接的异同。
答: udp前者只管传,不管数据到不到,无须建立连接. tcp后者保证传输的数据准确,须要连结.
25:ASP.net的身份验证方式有哪些?分别是什么原理? 答:Forms认证,windows集成认证等,passport验证 None 26:进程和线程分别怎么理解?
答:进程是老子,线程是儿子,没有老子就没有儿子,一个老子可以有多个儿子.一个儿子可以成为别人的儿子,一个老子也可以为别的老子生儿子. 27:什么是code-Behind技术。
答:代码分离,这是个明智的东西,或者可以理解成HTML代码写在前台,C#代码写在后台.当然前台也有脚本,类的调用等,其实写在一起也是可以的.
28:net中读写XML的类都归属于哪些命名空间? 答:System.Xml
29解释一下UDDI、WSDL的意义及其作用
答:UDDI 用于注册各个服务提供商提供的服务 以便可以共享它们 它还有助于WEB服务客户或web用户查找该Web服务
wsdl 是web服务描述语言(web Services Description Language)
30:什么是SOAP,有哪些应用。
答:SOAP(Simple Object Access Protocol )简单对象访问协议是在分散或分布式的环境中交换信息并执行远程过程调用的协议,是一个基于XML的协议。使用SOAP,不用考虑任何特定的传输协议(最常用的还是HTTP协议),可以允许任何类型的对象或代码,在任何平台上,以任何一直语言相互通信。这种相互通信采用的是XML格式的消息,具体请看
31:如何理解.net中的垃圾回收机制。
答 GC?对象创建了总要清除啊,不然内存哪够用? 32:常用的调用webservice方法有哪些? 答 HTTP-get Http-post Http-soap
33 概述.NET里对 remoting 和 webservice 两项技术的理解和实际中的应用。
答 远程逻辑调用,remoing接口只能用在.net中
34: 简述 private、 protected、 public、 internal 修饰符的访问权限。
答 private : 私有成员, 在类的内部才可以访问。
protected : 保护成员,该类内部和继承类中可以访问。 36:一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少, 用递归算法实现。 答:public class MainClass {
public static void Main() public : 公共成员,完全公开,没有访问限制。 internal: 在同一命名空间内可以访问。 35:列举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; }
{
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); }
}
37:override与重载的区别 答 :
override 与重载的区别。重载是方法的名称相同。参数或参数类型不同,进行多次重载以适应不同的需要 Override 是进行基类中函数的重写。为了适应需要。 38:请编程遍历页面上所有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 ; } }
39:请编程实现一个冒泡排序算法? 答:
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 ; } }
}
40:描述一下C#中索引器的实现过程,是否只能根据数字进行索引?
答:不是。可以用任意类型。
41:求以下表达式的值,写出您想到的一种或几种实现方法: 1-2+3-4+……+m 答:
int Num = this.TextBox1.Text.ToString() ; int Sum = 0 ;
for (int i = 0 ; i 〈 Num + 1 ; i++) {
if((i%2) == 1) {
Sum += i ; } else {
Sum = Sum - I ; } }
System.Console.WriteLine(Sum.ToString()); System.Console.ReadLine() ; 42:在下面的例子里 using System; class A {
public A() {
PrintFields(); }
public virtual void PrintFields(){} } class B:A { int x=1; int y; public B() {
y=-1; }
public override void PrintFields() {
Console.WriteLine(“x={0},y={1}“,x,y);
}
当使用new B()创建B的实例时,产生什么输出? 答:X=1,Y=0;x= 1 y = -1
43:net中读写数据库需要用到那些类?他们的作用? 答:DataSet:数据存储器。
DataCommand:执行语句命令。
DataAdapter:数据的集合,用于填充。
44:ASP.net的身份验证方式有哪些?分别是什么原理? 答:Windwos(默认)用IIS... From(窗体)用帐户 Passport(密钥)
45:在.net中,配件的意思是? 答:程序集。(中间语言,源数据,资源,装配清单) 46:net Remoting 的工作原理是什么?
答:服务器端向客户端发送一个进程编号,一个程序域编号,以确定对象的位置
47:根据委托(delegate)的知识,请完成以下用户控件中代码片段的填写: namespace test
{
public delegate void OnDBOperate();
public class UserControlBase :
System.Windows.Forms.UserControl
{
public event OnDBOperate OnNew;
privatevoidtoolBar_ButtonClick(objectsender,System.Windows.Forms.ToolBarButtonClickEventArgs e) {
if(e.Button.Equals(BtnNew)) {
//请在以下补齐代码用来调用OnDBOperate委托签名的OnNew事件。 }
} }
答:if( OnNew != null OnNew( this, e ;
48:SQLSERVER服务器中,给定表 table1 中有两个字段 ID、LastUpdateDate,ID表示更新的事务号, LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号
答:Select ID FROM table1 Where LastUpdateDate = (Select MAX(LastUpdateDate) FROM table1)
49:根据线程安全的相关知识,分析以下代码,当调用test方法时i〉10时是否会引起死锁?并简要说明理由。