C#.NET重点知识点汇总

填空题
1..NET Framework包括(CLR公共语言运行时)(框架类库)(实用工具)三种技术
2.运算符++X表示(计算完毕后增量X),X++表示(在计算前增量X)。
3.软件测试方法分为(黑盒测试)(白盒测试)。
4..NET通过对各语言先编译成(中间语言(IL)),然后再执行时用(JIT(即时编译器))将其编译成本地平台代码,来实现异构平台下对象的互操作
5.在SQL SERVER 中游标的声明的语句是(Declare Cursor)释放的语句是(Deallocate cursor)。
6.SQL SERVER的编程语言是(Transact-SQL)语言
7.委托声明的关键字是(Delegate)。
8.在MS SQL Server中,用来显示数据库信息的系统存储过程是(sp_helpdb)
9.SQL语言中,用于事务回滚的语句是(Rollback)。
10.如果两个实体之间具有M:N联系,则将它们转换为关系模型的结果是(3)个表。
11.Codebehind主要是通过把(页面代码)和(功能代码)放在不同的文件中来实现代码分离的。
12.在C#中由值类型转换为引用类型称为(装箱),有引用类型转换为值类型称为(拆箱)
13.SQL SERVER中索引类型包括的三种类型分别是(唯一索引)(簇索引)(非簇索引)。
14.软件工程的三大文档(系统需求说明书)(系统概要设计说明书)(系统详细设计说明书)
15.在SQL SERVER2000中的四中约束(主键)(唯一性)(外键)(检查约束)。;

B.简答题
1.什么是中间语言(IL)?它的作用?
中间语言代替了COM的调用约定和内存管理标准,所有其他的NET语言都将编译为这种语言,结果就是程序员不必来确保他们的代码将与一种确定的二进制标准进行互操作,而是由不同。NET语言编译器将代码编译到IL中来确保这种互操作性。

2.C#中与基类通信的关键字什么?作用是什么?
C#允许通过BASE关键字访问最近的基类成员。

3.什么是元数据?
描述程序集的内容,通过将元数据嵌入每个程序集中,任何程序集都可以实现完全的自我描述, 从而简化了发布使用较旧技术的组件时所需要的工作。

4.ASP.NET和ASP的主要优势?
a.ASP.NET具有面向对象性;b.ASP.NET使用ADO.NET,使对数据库操作更快速更强大;
c.ASP.NET支持多种语言,摆脱了ASP只能使用非结构语言(VBSCRIPT,JSCRIPT)编写的限制;d.ASP.NET具有代码绑定技术,使页面代码和功能代码的编写完全分离,具有更好的重用性.

5.Override与重载有什么区别?
Override用来重写父类的方法,重载使用相同名的方法或操作符拥有不同类型的参数。

6.SQL SERVER 中的触发器的理解?
触发器是一种特殊的存储过程,当用户修改指定表或视图中的数据时,触发器将自动执行.

7. ref、out的区别
ref修饰符用来通过引用传递参数,从而使得被调用方法能够更新参数的值.
Out修饰某个参数意味着该方法会把一个值从自身回传给调用函数.

8.大概描述下ASP.NET中服务器控件的生命周期?

9.什么是强类型系统?
中间语言一个重要方面是建立在非常强的类型化功能上.所有的变量都清晰地标记为属于某个特定数据类型,特别是如果给定的引用表示某个数据类型比较模糊的,那么中间语言一般不允许对它执行任何操作.

10.触发器分为事前触发和事后触发,有何区别?
事前触发器就是在语句执行之前激活的触发器,而事后触发器就是在语句执行后激活的触发器。

11.谈谈final, finally, finalize的区别。
final 修饰符用于指定类不能扩展或者方法或属性不能重写。它将防止其他类通过重写重要的函数来更改该类的行为。带有 final 修饰符的方法可以由派生类中的方法来隐藏或重载。
finally 块用于清除在 try 块中分配的任何资源。控制总是传递给 finally 块,与 try 块的存在方式无关。
finalize允许 Object 在“垃圾回收”回收 Object 之前尝试释放资源并执行其他清理操作。

12.在.net(C# or vb.net)中,Appplication.Exit 还是 Form.Close有什么不同?
一个是退出整个应用程序,一个是关闭其中一个form。

13.C#中的委托是什么?事件是不是一种委托?
委托是一个可以对方法进行引用的类。与其他的类不同,委托类具有一个签名,并且它只能对与其签名匹配的方法进行引用。这样,委托就等效于一个类型安全函数指针或一个回调。事件是一种委托.

14.值类型和引用类型的区别?
值类型的变量总是一个值,当声明时编译器分配与此类型相关联的字节数,而且你将直接操
已经分配的内存,另外在传递值类型的变量时,是在传递变量的值而不是它的底层对象的引用。而声明一个引用类型的变量时,是在操作对此对象的引用,而不是象值类型那样直接操作数据。主要的引用类型有:类,数组,接口,委托。

15.解释下C#中的方法的重载?
C#中允许在一个类中定义方法的不同版本,编译器会自动根据提供的参数选择最合适的版本。
16.分析类和结构的异同?
1.结构可以继承接口,但不允许继承类和其他结构;2.结构是值类型,类是引用类型;
3.结构不允许声明析构函数;4,结构是从堆栈分配内存,而类是从堆上分配内存。

17. &和&&的区别。
&是位运算符。&&是布尔逻辑运算符。

18.描述怎样区分ExcuteNonQuery 和ExcuteScalar方法?
ExecuteNonQuery;用于查询不返回结果集或者不返回除了所影响的行数之外的任何值.
ExecuteScalar:用于执行返回一个值的命令。

19.解释文件系统为什么会存在数据冗余?这种数据冗余会导致哪两类典型的问题?
由于文件系统难于实现数据共享,因此,相同的数据可能会在多个文件中重复出现,即产生数据冗余。数据冗余会导致数据(或更新)异常和数据不一致性。

20.什么是WEBSERVICE?
从表面上看,Web Service就是一个应用程序,它向外界暴露出一个能够通过Web进行调用的API。这就是说,你能够用编程的方法通过Web调用来实现某个功能的应用程序。从深层次上看,Web Service是一种新的Web应用程序分支,它们是自包含、自描述、模块化的应用,可以在网络(通常为Web)中被描述、发布、查找以及通过Web来调用。

21.接口和抽象类有什么区别?
声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创建一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类的情况。不能创建abstract 类的实例。然而可以创建一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态方法。Abstract 类的子类为它们父类中的所有抽象方法提供实现,否则它们也是抽象类为。取而代之,在子类中实现该方法。知道其行为的其它类可以在类中实现这些方法。接口(interface)是抽象类的变体。在接口中,所有方法都是抽象的。多继承性可通过实现这样的接口而获得。接口中的所有方法都是抽象的,没有一个有程序体。接口只可以定义static final成员变量。接口的实现与子类相似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给予)所有这种接口的方法。然后,它可以在实现了该接口的类的任何对象上调用接口的方法。由于有抽象类,它允许使用接口名作为引用变量的类型。通常的动态联编将生效。引用可以转换到接口类型或从接口类型转换,instanceof 运算符可以用来决定某对象的类是否实现了接口。

22.描述类中的构造函数和析构函数?
构造函数用于在使用对象之前,对对象中的成员数据进行初始化.一般与类同名;析构函数用在撤消对象时,承担善后处理工作,比如收回对象中的成员数据所占有的存储空间.

23.解释下C#中的程序集?
用于代替DLL和可执行文件(EXE)概念的自我描述.程序集由中间语言和元数据组成。


24.try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后?
会执行, 在return前执行。

25.SQL SERVER的两种索引是何形式?索引的作用?索引的优缺点?
SQL SERVER 提供了两中索引形式:簇集索引和非簇集索引.索引是SQL SERVER在列上建立的一种数据库对象.它对表中的数据提供逻辑排序,可以提高数据的访问速度.建立索引也有缺点,它可以提高查询速度,但过多的建立索引会占据大量的磁盘空间.

26.谈谈C/S和B/S的特点
C/S结构 是客户端和服务器机构 ;B/S是浏览器和服务器结构;
C/S结构应用服务器运行数据负荷较轻,数据存储管理较为透明,C/S架构的劣势是高昂的维护成本;.B/S结构维护和升级方式简单,成本降低,选择很多,应用服务器运行数据负荷较轻;.C/S多建立在局域网基础上,B/S是建立在广域网基础上。

C.编程题:
1.设有如下关系表
供应者 SUPPLIER(SNO,SNAME,CITY) SNO供应者编号,SNAME为供应者姓名,CITY所在城市
零件 PART(PNO,PNAME,WEIGHT)PNO零件号,PNAME零件名称,WEIGHT重量
工程 JOB(JNO,JNAME,CITY) JNO工程号,JNAME工程名,CITY所在城市
联系关系 SPJ(SNO,PNO,JNO,QTY) QTY为数量
1.查找给工程J1提供零件P1的供应者号SNO
SELECT SNO FROM SPJ WHERE PNO=“P1”AND JNO=“J1”
2.查找在北京的供应者给武汉的工程提供零件的零件号
SELECT PNO FROM SPJ WHERE JNO IN(SELECT JNO FROM JOB WHERE CITY=“武汉”)
AND SNO IN (SELECT SNO FROM SUPPLIER WHERE CITY=“北京”)
3.查找由供应者S1提供的零件名PNAME
SELECT PNAME FROM PART WHERE PNO IN(SELECT PNO FROM SPJ WHERE SNO=“S1”)
4.查找CITY值为上海的工程号和名称
SELECT 工程号,名称 FROM JOB WHERE CITY=“上海“
5.将工程J3的城市改为广州
UPDATE JOB SET CITY=“广州“ WHERE JNO=”13“
6.将所有重20公斤的零件改为重10公斤
UPDATE JOB SET CITY=“广州“ WHERE JNO=”13“
7.将给工程J1提供零件P1的供应者S1改为S2
UPDATE SPJ SET SNO=“S2”
WHERE(JNO=“J1” AND PNO=“P1” AND SNO=“S1”)
8.将值(S3,凌涛,武汉)加到SUPPLIER中
INSERT INTO SUPPLIER(SNO,SNAME,CITY)
9.删除所有上海工程的数据
DELETE FROM JIB WHERE CITY=“上海”


2.有个表USERS如下
Number(int) Name(char)
1 a
2 b
3 b
4 a
5 c
6 c
要求:当Name列上有相同时,只保留Number这列上值小的那一行,结果应如下:
Number(int) Name(char)
1 a
2 b
5 c
问:用SQL语句的Delete来实现.(记住,是一个SQL语句)
DELETE * FROM Users WHERE Number NOT IN (Select Min(Number) FROM Users
GROUP BY Name)

A.填空题:
1.类的三大特性是(封装性)(继承性)(多态性)。
2.在SELECT语句的FROM子句中最多可以指定(256)个表或视图,相互之间要用(,)分隔,当所查询的表不在当前数据库时,可用(数据库.所有者名称.对象名称)格式来指出表或视图对象。
3.创建存储过程的命令是(create procedure),删除表的命令是(drop table)。
4.计算字段的累加和的函数是:(Sum()),统计项目数的函数是:(Count())。
5.关系数据库中,主键是(为标识表中唯一的实体)。
6.声明抽象类的关键字是(abstract),抽象类不能(实例化)。
7..NET运行库支持被称为(委托)的引用类型,其作用类似于C++中函数指针的用途。
8.XML的全称是(可扩展的标记语言)。
9.C#中所有的类型实质上都是从(object)类派生而来的。
10. 声明静态变量的关键字是(static),声明常量的关键字是(const)。
11.C#中处理内存管理功能的是(无用单元收集器)。
12.在C#中用于显式地将一个值或引用转换为另一种不同的类型称为(强制类型转换)
13.在ADO.NET中,command对象是用(ExecuteNomQuery)(ExecuteScalar)(ExecuteReader)方法执行命令。
14.B/S通常使用的结构设计模型分为(表示层)(业务逻辑层)(数据库层)。
15.SQL SERVER中索引类型包括的三种类型分别是(唯一索引)(簇索引)(非簇索引)。

B.简答题:
1.什么是中间语言(IL)?它的作用?
中间语言代替了COM的调用约定和内存管理标准,所有其他的NET语言都将编译为这种语言,结果就是程序员不必来确保他们的代码将与一种确定的二进制标准进行互操作,而是由不同。NET语言编译器将代码编译到IL中来确保这种互操作性。

2.什么是装箱和拆箱?
装箱是将值类型转换为引用类型的过程,相反的过程(即将引用类型转换为值类型)被称为拆箱。在装箱是不需要显示的类型转换,但在拆箱是需要类型转换,这是因为在拆箱是对象可以被转换为任何类型。

3.出ADO.NET中读写数据库的主要的几个类?它们的作用?
SqlConnection OleDbConnection ---连接数据库
SqlCommand OleDbCommand----SQL语句的包装或存储过程的调用
SqlDataAdapter OleDbDataAdapter---用于存储选择,插入,更新和删除语句的类,填充DataSet。
SqlDataReader OleDbDataReader---只向前的连接数据库读取器
DataSet----用于数据库操作的数据集。

4.C#中接口和类有什么异同?
接口类似于类,但它们有区别:a.接口中的方法没有访问限制符;b.在接口中不执行任何方法;c.接口中的方法不能如抽象方法那样定义为虚拟和显式的,由实现接口的类来决定如何实现方法;d.接口不能示例化,没有构造函数,也没有字段,在接口中不允许进行操作符的重载。

5. 解释ASP.NET中的code-behind?
将页面的编码和功能编码分离,使代码的改进更为方便。

6.什么是ASP.NET中的用户控件?
用户控件是用ASP.NET代码所创建的控件,它的创建如同在标准的ASP.NET WEB页中创建控件一样,不同之处在于一旦创建了用户控件,就可以在多个ASP.NET页面中重复使用他们。

7.在C#中,string str = null 与 string str = “” 请尽量说明其中的区别。
string str = null 是不给他分配内存空间,而string str = ““ 给它分配长度为空字符串的内存空间。

8. 什么是受管制代码?
在.NET环境中运行的任何代码都是受管制代码。在。NET环境外部的其他代码也运行在WINDOWS上的,为非受管制代码。

9.C#中常用的访问形式?它们各自的作用域?
Public 用来声明所有对象都可以使用的方法或属性。
Private 用来指出只有拥有该方法或属性的类才能访问该方法或属性。
Protected 用来指定属性或方法的作用域,这样就只有拥有该方法或属性的类以及该类的派生类才能访问该属性或方法。
Internal 用来指定属性或方法在一个程序集内部的作用域。

10. SQL SERVER 中的存储过程的理解?
存储过程是一组预先编译好的T-SQL代码,存储过程可以作为一个单元被用户的应用程序调用.由于是已经编译好的代码,所以执行起来不必再次编译,从而提高了程序的运行效率。

11.CTS,CLS,CLR分别作何解释?
公共语言运行时(CLR):它实际管理代码,它可以处理和加载程序,运行程序的代码,以及提供所有支持服务的代码。
公共类型系统(CTS):为了实现语言的互操作性,必须有一组各种语言都认可的基本数据类型,这样才能对所有语言进行标准化管理。
公共语言规范(CLS):这是确保代码可以在任何语言中访问的最小标准集合,所有用于。

12.ASP.NET和ASP的主要优势?
a.ASP.NET具有面向对象性;b.ASP.NET使用ADO.NET,使对数据库操作更快速更强大;
c.ASP.NET支持多种语言,摆脱了ASP只能使用非结构语言(VBSCRIPT,JSCRIPT)编写的限制;d.ASP.NET具有代码绑定技术,使页面代码和功能代码的编写完全分离,具有更好的重用性.

13.NET的错误处理机制是什么?
.net错误处理机制采用try->catch->finally结构,发生错误时,层层上抛,直到找到所匹配的Catch为止。

14.解释Page.IsPostBack属性?
Page.IsPostBack是用来检查目前网页是否为第一次加载,当使用者第一次浏览这个网页是Page.IsPostBack会传会FALSE,否则为TRUE,所以使用该属性来避免做一些重复的动作。

15..net framework包含哪几种技术?
.net framewor本事可视为三中不同的技术:公共语言进行时(CLR),框架类库和实用工具。

16.触发器分为事前触发和事后触发,有何区别?
事前触发器就是在语句执行之前激活的触发器,事后触发器就是在语句执行后激活的触发器。

17.解释SQL SERVER2000中HAVING的用法?
当完成数据结果的查询和统计后,可以使用HAVING关键字来对查询和计算的结果进一步筛选。

18.解释SQL SERVER2000中GROUP BY的用法?
如果需要按某一列数据的值进行分类,在分类的基础上再进行查询,就需要使用GROUP BY。

19.解释下C#中的方法的重载?
C#中允许在一个类中定义方法的不同版本,编译器会自动根据提供的参数选择最合适的版本。

20.事务是什么?
事务的所有操作必须完成,否则事务将被撤消。也就是说,事务是作为一个整体的单位处理,不可以被分割,事务中操作失败回滚,处理成功时提交。

21.描述下ASP.NET中使用DataReader对象 和DataSet对象的区别?
DataReader对象是只向前的连接数据读取器,使用它可以快速有效地访问数据.
DataSet对象提供一个内存中数据的关系表示形式,一整套包括一些表在内的数据(这些表包含数据、对数据进行排序并约束数据),以及表之间的关系.
DataReader对象会使得SQL SERVER的连接处于忙碌桩,以便只有在关闭DataReader之后才可以在这个连接上执行其他操作.
DataSet对象可以可以看作是DATATABLE对象的容器,可以在数据库操作时将多个表的所有数据都放在DataSet中,用在单独一次调用中将其返回,避免了重复调用的过程.
DataSet对象的调用将在内存开辟一个虚拟的表.因此将占有相当的内存空间。

22.分析类和结构的异同?
a.结构可以继承接口,但不允许继承类和其他结构;b.结构是值类型,类是引用类型;
b.结构不允许声明析构函数;d,结构是从堆栈分配内存,而类是从堆上分配内存。

23.解释ADO.NET中的使用Connection 类的close()和dispose()的区别?
Close方法关闭数据库连接,并将这个连接返回到连接池.因此程序可以再次使用这个连接;Dispose方法释放所有与连接有关的资源。

24.叙述ADO.NET中的DataAdapte类的作用?
DataAdapte类是数据集和数据提供程序的主要接口。利用这个类能够填充数据集,管理和维护数据,以及将更新发送回数据存储器。

25.什么是WEBSERVICE ?
从表面上看,Web Service就是一个应用程序,它向外界暴露出一个能够通过Web进行调用的API。这就是说,你能够用编程的方法通过Web调用来实现某个功能的应用程序。从深层次上看,Web Service是一种新的Web应用程序分支,它们是自包含、自描述、模块化的应用,可以在网络(通常为Web)中被描述、发布、查找以及通过Web来调用。

26.行下面代码后:
String strTemp = "abcdefg 某某某";
Int I System.Text.Encoding.Default.GetBytes(strTemp).Length;
Int j = strTemp.Length;
问:i=(13) ;j=(11)
原因是什么?原因是汉字占2个字节

27.叙述ASP.NET中的几种验证控件(equiredFieldValidato, CompareValidator, RangeValidator,RegularExpressionValitor,CustomValidator, ValidationSummary)及作用?
equiredFieldValidator 如果指定的文本控件空白,产生错误
CompareValidator 将文本控件的值与特定值比较,如果返回FALSE,产生错误RangeValidator 文本域的值落在一个指定区域外,产生错误
RegularExpressionValitor 文本域的值与使用常规表达式指定的模式不匹配是,产生错误CustomValidator 调用自定义逻辑,根据返回的值产生错误
ValidationSummary 在一个特定区域内显示验证错误的文本

C.编程题:
1.有三个表,结构如下:
STUDENT(学生证号,姓名,性别,出生年月)
COURSE(课程号,课程名,授课教师)
SC(学生证号,课程号,成绩,授课教师)
用标准SQL 语句完成下列操作:
a. 查询女生的基本情况,并按照学生证号降序排列。
SELECT * FROM STUDENT WHERE 性别=‘女’ ORDER BY 学生证号 DESC
b. 查询成绩在90分以上的学生的姓名
SELECT 姓名 FROM STUDENT WHERE 学生证号 IN
(SELECT 学生证号 FROM SC WHERE 成绩 < 90 )
c. 查询数学类课程的课程号和课程名(模糊查询,以S开头)
SELECT 课程号,课程名 FROM COUSE LIKE “S%”
d.查询选课学生所选课程的课程号和成绩,以及该学生的姓名和性别
SELECT SC.课程号,SC.成绩,STUDENT.姓名,STUDENT.性别 FROM SC,STUDENT
WHERE SC.学生证号= STUDENT.学生证号
e.查询03号课程的平均成绩
SELECT AVG(成绩) FROM SC WHERE 课程号=‘03’
f.删除成绩不及格的学生姓名
DELETE 学生姓名 FROM STUDENT WHERE 学生证号
(SELECT学生证号 FROM SC WHERE 成绩〈60)
j.把学生证号为90876的学生所选的01号课程成绩改为80分
UPDATE SC SET 成绩=80 WHERE (学生证号=‘90876’)AND(课程号=‘01’)

2.SQLSERVER服务器中,给定表 table1 中有两个字段 ID、LastUpdateDate,ID表示更新的事务号, LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号。
SELECT ID FROM table1
WHERE LastUpdateA.填空题
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) Date = (SELECT MAX(LastUpdateDate) FROM table1)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值