A.填空题
1.类的三大特性是(封装性)(继承性)(多态性)。
2.SQL语言中,用于事务回滚的语句是(rollback)。
3.声明静态变量的关键字是(static),声明常量的关键字是(const)。
4.软件工程的三大文档(需求分析)(概要设计)(详细设计)。
5.为数据表创建索引的目的是(提高查询的检索性能)。
6.B/S通常使用的结构设计模型分为(表示层)(业务逻辑层)(数据库层)。
7.SQL SERVER中索引类型包括的三种类型分别是(唯一索引)(簇索引)(非簇索引)。
8.在SQL SERVER2000中的四中约束(主键)(唯一性)(外键)(检查约束)。
9.Codebehind主要是通过把(页面代码)和(功能代码)放在不同的文件中来实现代码分离的。
10.计算字段的平均值和最大值的函数是:(Average())(Max())
11.XML的全称是(可扩展标记语言),提供了快速和有效地读写XML的方式的类分别是(
XmlTextReader)(XmlTextWriter)。;
12. SQL SERVER 中的存储过程是(存储过程是一组预先编译好的T-SQL代码)。
13.C#中所有的类型实质上都是从(object)类派生而来的。
14..NET运行库支持被称为(委托)的引用类型,其作用类似于C++中函数指针的用途。
15. 在流程控制中CONTINUE的作用(终止当前循环)
B.简答题
1.描述下C#中的程序集?程序集是有哪两部分组成?
用于代替DLL和可执行文件(EXE)概念的自我描述.程序集由中间语言和元数据组成。
2.什么是元数据?
描述程序集的内容,通过将元数据嵌入每个程序集中,任何程序集都可以实现完全的自我描述, 从而简化了发布使用较旧技术的组件时所需要的工作.
3.请写出 BOOL flag 与“零值”比较的 if 语句?请写出 char p 与“零值”比较的 if 语句?
if(flag) if(flag==null)
4.说出下面几个函数的区别:
private void test(string str){…}被调用函数不更新参数的值,因为传递的是参数的副本
private void test(ref string str){…}关键字REF用来引用传递参数,从而使得被调用方法能够更新参数的值.
private void test(out string str){…} OUT修饰参数,是该方法会把一个值从自身回传给调用函数.
5.什么是强类型系统?
中间语言一个重要方面是建立在非常强的类型化功能上.所有的变量都清晰地标记为属于某个特定数据类型,特别是如果给定的引用表示某个数据类型比较模糊的,那么中间语言一般不允许对它执行任何操作.
6.值类型和引用类型的区别?
值类型的变量总是一个值,当声明时编译器分配与此类型相关联的字节数,而且你将直接操已经分配的内存,另外在传递值类型的变量时,是在传递变量的值而不是它的底层对象的引用。而声明一个引用类型的变量时,是在操作对此对象的引用,而不是象值类型那样直接操作数据。主要的引用类型有:类,数组,接口,委托。
7.如何理解委托?
委托是一个可以对方法进行引用的类。与其他的类不同,委托类具有一个签名,并且它只能对与其签名匹配的方法进行引用。这样,委托就等效于一个类型安全函数指针或一个回调。事件是一种委托.
8.事务是什么?
事务的所有操作必须完成,否则事务将被撤消。也就是说,事务是作为一个整体的单位处理,不可以被分割,事务中操作失败回滚,处理成功时提交。
9.解释重载函数、虚拟函数的概念?
重载分为函数重载和运算符重载。通过使用重载机制,可以对一个函数名(或运算符)定义多个函数(或运算功能)只不过要求这些函数的参数(或参加运算的操作数)类型有所不同。
函数重载:指一组功能类似但函数参数类型(个数)不同的函数可以共用一个函数名.当编译器遇到重载函数的调用语句时,它能够根据不同的参数类型或不同的参数个数选择一个合适的函数.
运算符重载:指对于不同数据类型的操作数,同一个运算符所代表的运算功能可以不同.
虚函数是用于实现多态的机制。就是通过基类访问派生类定义的函数。虚函数一般是在派类中使用同基类相同的函数的时候用的,为了正确区分所要调用的函数是基类还是派生类函数。若在派生类中声明了一个虚函数则调用的是派生类中的函数,而非基类中的函数。
10.请简述以下两个for循环的优缺点
for (i=0; i<N; i++)
{
if (condition)
DoSomething();
else
DoOtherthing();
}
--------
if (condition)
{
for (i=0; i<N; i++)
DoSomething();
}
else
{
for (i=0; i<N; i++)
DoOtherthing();
}
第一个优点:程序简洁;缺点:多执行了N-1次逻辑判断,并且打断了循环“流水线”作业,使得编译器不能对循环进行优化处理,降低了效率。
第二个优点:循环的效率高;缺点:程序不简洁。
11.描述描述怎样区分ExcuteNonQuery ,ExcuteDataReader和ExcuteScalar方法?
ExecuteNonQuery;用于查询不返回结果集或者不返回除了所影响的行数之外的任何值.
ExecuteScalar:用于执行返回一个值的命令.
ExecuteReader:用于执行命令,并将结果集作为DataReader对象返回.
12. 列出ADO.NET中读写数据库的主要的几个类?它们的作用?
SqlConnection OleDbConnection >> 连接数据库
SqlCommand OleDbCommand >> SQL语句的包装或存储过程的调用
SqlDataAdapter OleDbDataAdapter >> 用于存储选择,插入,更新和删除语句的类,
填充DataSet
SqlDataReader OleDbDataReader >> 只向前的连接数据库读取器
DataSet>> 用于数据库操作的数据集。
13. 什么是中间语言(IL)?它的作用?
中间语言代替了COM的调用约定和内存管理标准,所有其他的NET语言都将编译为这种语言,结果就是程序员不必来确保他们的代码将与一种确定的二进制标准进行互操作,而是由不同。NET语言编译器将代码编译到IL中来确保这种互操作性。
14. 在SQL SERVER2000中存储过程和触发器的区别?
1.存储过程是一段预先编译好的T-SQL代码,可以被重复调用,触发器是在进行表更改操作
时才执行功能.
2.触发器执行的时间较长,性能较低;存储过程重用性好,执行性能较高.
3.触发器多用在完善表的数据完整性和约束;存储过程多用在方便重复使用数据库操作.
15.在ASP.NET中页面之间传递值的方式?(尽可能叙述)
Session;Cookie;Server;Transfer;QueryString
16.分析类和结构的异同?
1.结构可以继承接口,但不允许继承类和其他结构;2.结构是值类型,类是引用类型;
3.结构不允许声明析构函数;4,结构是从栈分配内存,而类是从堆上分配内存。
17.short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
short s1 = 1; s1 = s1 + 1;有错,s1是short型,s1+1是int型,不能显式转化为short型。可修改为s1 =(short)(s1 + 1)。short s1 = 1; s1 += 1正确。
18.叙述ASP.NET中的equiredFieldValidator和RegularExpressionValitor验证控件及作用?
RequiredFieldValidator 如果指定的文本控件空白,产生错误
RegularExpressionValitor 文本域的值与使用常规表达式指定的模式不匹配是,产生错误。
19.叙述下Using 的用法?
Using语句用来确保即使发生异常,也会调用dispose方法,来释放系统空闲的资源。
20.C#中接口和类有什么异同?
接口类似于类,但它们有区别:接口中的方法没有访问限制符;在接口中不执行任何方法;
接口中的方法不能如抽象方法那样定义为虚拟和显式的,由实现接口的类来决定如何实现方法;接口不能示例化,没有构造函数,也没有字段,在接口中不允许进行操作符的重载。
21.什么是装箱和拆箱?
装箱是将值类型转换为引用类型的过程,相反的过程(即将引用类型转换为值类型)被称为拆箱。在装箱是不需要显示的类型转换,但在拆箱是需要类型转换,这是因为在拆箱是对象可以被转换为任何类型。
22.什么是WEBSERVICE ?
从表面上看,Web Service就是一个应用程序,它向外界暴露出一个能够通过Web进行调用的API。这就是说,你能够用编程的方法通过Web调用来实现某个功能的应用程序。从深层次上看,Web Service是一种新的Web应用程序分支,它们是自包含、自描述、模块化的应用,可以在网络(通常为Web)中被描述、发布、查找以及通过Web来调用。
23.软件开发过程一般有几个阶段?
系统需求分析,系统概要设计,系统详细设计,编码,系统测试,安装调试。
24.在ASP。NET中自定义控件是什么?
用户控件是用ASP.NET代码所创建的控件,它的创建如同在标准的ASP.NET WEB页中创建控件一样,不同之处在于一旦创建了用户控件,就可以在多个ASP.NET页面中重复使用他们。
25.ASP.NET的Application、Session、Cookie、ViewState、Cache 、Hidden等变量的区别是什么?
Application
1.Application用来保存所有用户共用的信息;
2.在Asp时代,如果要保存的数据在应用程序生存期内不会或者很少发生改变,那么使用Application是理想的选择。但是在Asp.net开发环境中我们把类似的配置数据放在Web.config中;
3. 如果要使用Application 要注意的是所有的写操作都要在Application_OnStart事件中完成(global.Asax),尽管可以使用Application.Lock()避免了冲突,但是它串行化了对Application的请求,会产生严重的性能瓶颈;
4.不要使用Application保存大数据量信息;
5.代码:Application[“UserID”]=”test”;
String UserName=Application[“UserID”].ToString();
Session
1.Session用来保存每一个用户的专有信息;
2.Session的生存期是用户持续请求时间加上一段时间(一般是20分钟左右);
3.Session信息是保存在Web服务器内存中的,保存数据量可大可小;
4.Session超时或者被关闭将自动释放数据信息;
5.由于用户停止使用应用程序之后它仍在内存中存留一段时间,因此这种方法效率较低
6.代码:Session[“UserID”]=”test”;
String UserName=Session[“UserID”].ToString()。
Cookie
1.Cookie用来保存客户浏览器请求服务器页面的请求信息;
2.我们可以存放非敏感的用户信息,保存时间可以根据需要设置;
3.如果没有设置Cookie失效日期,它的生命周期保存到关闭浏览器为止;
4. Cookie对象的Expires属性设置为MinValue表示永不过期;
5. Cookie存储的数据量受限制,大多数的浏览器为4K因此不要存放大数据;
6.由于并非所有的浏览器都支持Cookie,数据将以明文的形式保存在客户端;
7.代码:Resopnse.Cookies[“UserID”]=”test”;
String UserName= Resopnse.Cookies [“UserID”].ToString();
ViewState
1.ViewState用来保存用户的状态信息,有效期等于页面的生命周期;
2.可以保存大量数据但是要慎用,因为会影响程序性能;
3.所有的Web服务器控件都是用ViewState在页面PostBack期间保存状态;
4.不需要则关闭 @page 里面设置EnableViewState=false;
5.代码:ViewState[‘”ID”]=”yiner”;
String ID =ViewState[“ID”].ToString()。
Cache
1. Cache用于在Http请求期间保存页面或者数据;
2. Cache的使用可以大大的提高整个应用程序的效率;
3. 它允许将频繁访问的服务器资源存储在内存中,当用户发出相同的请求后服务器不是再次处理而是将Cache中保存的数据直接返回给用户;
4.可以看出Cache节省的是时间—服务器处理时间;
5.Cache实例是每一个应用程序专有的,其生命周期==该应用程序周期应用程序重启将重新创建其实例;
6.注意:如果要使用缓存的清理、到期管理、依赖项等功能必须使用Insert 或者Add方法方法添加信息;
7.代码:Cache[‘”ID”]=”yiner”;或者Cache.Insert(“ID”,”test”);
String ID =Cache[“ID”].ToString();
Hidden
1.Hidden控件属于Html类型的服务器控件,始终处于隐藏状态;
2.每一次提交的时候它会和其他服务器控件一起提交到服务器端;
3. 代码如下:Hidden.Value=”king”;string id=Hidden.Value; 要使用Runat=server。
26.解释下在ASP.NET中Response的作用?
与Request获取客户端HTTP信息相反, Response用来控制发送给用户的信息,包括直接发送信息给浏览器,重定向到另一个ULR或设置COOKIE值。
27.解释下在ASP.NET中Request的作用?
Request访问任何基于HTTP请求传递的所有信息,包括从HTML表格用POST方法和GET方法传递的参数,COOKIE和用户人证。
28. C#中能够使用指针吗?如果不能使用说明理由,如果能使用说出使用方法?
C#中能够使用指针,因为在.NET框架内使用无用单元回收器,隐藏了内存的管理工作.所以C#只允许在特定的代码块内使用指针,标记所用的关键字是unsafe。
29. 浅谈property和attribute区别.
property和attribute汉语都称之为属性。不过property是指类向外提供的数据区域。而attribute则是描述对象在编译时或运行时属性的。这两者是有本质区别的。
C.编程题:
1.为管理岗位业务培训信息,建立3个表:
S (S#,SN,SD,SA) S#,SN,SD,SA 分别代表学号、学员姓名、所属单位、学员年龄
C (C#,CN) C#,CN 分别代表课程编号、课程名称
SC ( S#,C#,G ) S#,C#,G 分别代表学号、所选修的课程编号、学习成绩
1.使用标准SQL嵌套语句查询选修课程名称为’税收基础’的学员学号和姓名
SELECT S#,SN FROM S WHERE S# IN(SELECT S# FROM C,SC
WHERE C.C#=SC.C# AND CN='税收基础')
2. 使用标准SQL嵌套语句查询选修课程编号为’C2’的学员姓名和所属单位
SELECT S.SN,S.SD FROM S,SC WHERE S.S#=SC.S# AND SC.C#='C2'
3. 使用标准SQL嵌套语句查询不选修课程编号为’C5’的学员姓名和所属单位
SELECT SN,SD FROM S WHERE S# NOT IN(SELECT S# FROM SC WHERE C#='C5')
4. 使用标准SQL嵌套语句查询选修全部课程的学员姓名和所属单位
SELECT SN,SD FROM S WHERE S# IN(SELECT [S#] FROM SC
RIGHT JOIN C ON SC.C#=C.C# GROUP BY S# HAVING COUNT *=COUNT(S#))
5. 查询选修了课程的学员人数
SELECT 学员人数=COUNT(DISTINCT S#) FROM SC
6. 查询选修课程超过5门的学员学号和所属单位
SELECT SN,SD FROM S WHERE S# IN(SELECT S# FROM SC GROUP BY S#
HAVING COUNT(DISTINCT C#)>5 )
2.SQLSERVER服务器中,给定表 table1 中有两个字段 ID、LastUpdateDate,ID表示更新的事务号, LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号。
SELECT IDFROM table1
WHERE LastUpdateDate = (SELECT MAX(LastUpdateDate) FROM table1)