c#面试题.docx
- 文档编号:9658546
- 上传时间:2023-02-05
- 格式:DOCX
- 页数:145
- 大小:80.73KB
c#面试题.docx
《c#面试题.docx》由会员分享,可在线阅读,更多相关《c#面试题.docx(145页珍藏版)》请在冰豆网上搜索。
c#面试题
内容正文:
1、在C#中,stringstr=null与stringstr=“”请尽量使用文字或图象说明其中的区别。
回答要点:
说明详细的空间分配。
(10分)
答:
stringstr=null是不给他分配内存空间,而stringstr=“”给它分配长度为空字符串的内存空间.
2、请详述在dotnet中类(class)与结构(struct)的异同:
(10分)
答:
Class可以被实例化,属于引用类型,是分配在内存的堆上的,Struct属于值类型,是分配在内存的栈上的.
3、根据委托(delegate)的知识,请完成以下用户控件中代码片段的填写:
(10)
namespacetest
{
publicdelegatevoidOnDBOperate();
publicclassUserControlBase:
System.Windows.Forms.UserControl
{
publiceventOnDBOperateOnNew;
privatevoidtoolBar_ButtonClick(objectsender,System.Windows.Forms.ToolBarButtonClickEventArgse)
{
if(e.Button.Equals(BtnNew))
{
//请在以下补齐代码用来调用OnDBOperate委托签名的OnNew事件。
}
}
}
答:
if(OnNew!
=null)
OnNew(this,e);
4、分析以下代码,完成填空(10分)
stringstrTmp=“abcdefg某某某”;
inti=System.Text.Encoding.Default.GetBytes(strTmp).Length;
intj=strTmp.Length;
以上代码执行完后,i=j=
答:
i=13,j=10
5、SQLSERVER服务器中,给定表table1中有两个字段ID、LastUpdateDate,ID表示更新的事务号,LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号。
(10)
答:
SelectID
FROMtable1
WhereLastUpdateDate=(SelectMAX(LastUpdateDate)FROMtable1)
6、根据线程安全的相关知识,分析以下代码,当调用test方法时i>10时是否会引起死锁?
并简要说明理由。
(10分)
publicvoidtest(inti)
{
lock(this)
{
if(i>10)
{
i--;
test(i);
}
}
}
答:
不会发生死锁,(但有一点int是按值传递的,所以每次改变的都只是一个副本,因此不会出现死锁。
但如果把int换做一个object,那么死锁会发生)
7、分析以下代码。
(10)
publicstaticvoidtest(stringConnectString)
{
System.Data.OleDb.OleDbConnectionconn=newSystem.Data.OleDb.OleDbConnection();
conn.ConnectionString=ConnectString;
try
{
conn.Open();
…….
}catch(ExceptionEx)
{
MessageBox.Show(Ex.ToString());
}finally
{
if(!
conn.State.Equals(ConnectionState.Closed))
conn.Close();
}
请问
1}以上代码可以正确使用连接池吗?
答:
回答:
如果传入的connectionString是一模一样的话,可以正确使用连接池。
不过一模一样的意思是,连字符的空格数,顺序完全一致。
2}以上代码所使用的异常处理方法,是否所有在test方法内的异常都可以被捕捉并显示出来?
答:
只可以捕捉数据库连接中的异常吧.(finally中,catch中,如果有别的可能引发异常的操作,也应该用try,catch。
所以理论上并非所有异常都会被捕捉。
)
8、简要谈一下您对微软.NET构架下remoting和webservice两项技术的理解以及实际中的应用。
(10)
答:
WS主要是可利用HTTP,穿透防火墙。
而Remoting可以利用TCP/IP,二进制传送提高效率。
9、公司要求开发一个继承System.Windows.Forms.ListView类的组件,要求达到以下的特殊功能:
点击ListView各列列头时,能按照点击列的每行值进行重排视图中的所有行(排序的方式如DataGrid相似)。
根据您的知识,请简要谈一下您的思路:
(10)
答:
根据点击的列头,包该列的ID取出,按照该ID排序后,在给绑定到ListView中
10、给定以下XML文件,完成算法流程图。
(10)
请画出遍历所有文件名(FileName)的流程图(请使用递归算法)。
答:
voidFindFile(Directoryd)
{
FileOrFolders=d.GetFileOrFolders();
foreach(FileOrFolderfofinFileOrFolders)
{
if(fofisFile)
YouFoundafile;
elseif(fofisDirectory)
FindFile(fof);
}
}
简单的说就是从根节点开始遍历找子节点,在从找到的子节点找它的子节点,一层层下去
果你的简历上面写“熟悉/了解C#”,那么你就应该能够回答下面的这些基础问题。
我将给出自己的简要答案以供参考。
欢迎讨论。
传入某个属性的set方法的隐含参数的名称是什么?
value,它的类型和属性所声名的类型相同。
如何在C#中实现继承?
在类名后加上一个冒号,再加上基类的名称。
C#支持多重继承么?
不支持。
可以用接口来实现。
被protected修饰的属性/方法在何处可以访问?
在继承或间接继承与这个类的子类中可以访问。
私有成员会被继承么?
会,但是不能被访问。
所以看上去他们似乎是不能被继承的,但实际上确实被继承了。
请描述一下修饰符protectedinternal。
被protectedinternal修饰的属性/方法只能在它的在同一个程序集(Assembly)中的子类被访问。
C#提供一个默认的无参数构造函数,当我实现了另外一个有一个参数的构造函数时候,还想保留这个无参数的构造函数。
这样我应该写几个构造函数?
两个,一旦你实现了一个构造函数,C#就不会再提供默认的构造函数了,所以需要手动实现那个无参数构造函数。
C#中所有对象共同的基类是什么?
System.Object.
重载和覆写有什么区别?
重载提供了对一个方法签名的不同参数调用的实现。
覆写提供了子类中改变父类方法行为的实现。
在方法定义中,virtual有什么含意?
被virtual修饰的方法可以被子类覆写。
能够将非静态的方法覆写成静态方法么?
不能,覆写方法的签名必须与被覆写方法的签名保持一致,除了将virtual改为override。
可以覆写私有的虚方法么?
不可以,甚至子类中无法访问父类中的私有方法。
能够阻止某一个类被其他类继承么?
可以,使用关键字sealed。
能够实现允许某个类被继承,但不允许其中的某个方法被覆写么?
可以,标记这个类为public,并标记这个方法为sealed。
什么是抽象类(abstractclass)?
一种不可以被实例化的类。
抽象类中一般含有抽象方法,当然也可有具体实现。
继承类只有实现过所有抽象类的抽象方法后才能被实例化。
何时必须声明一个类为抽象类?
当这个类中包含抽象方法时,或是该类并没有完全实现父类的抽象方法时。
接口(interface)是什么?
只含有共有抽象方法(publicabstractmethod)的类。
这些方法必须在子类中被实现。
为什么不能指定接口中方法的修饰符?
接口中的方法用来定义对象之间通信的契约,指定接口中的方法为私有或保护没有意义。
他们默认为公有方法。
可以继承多个接口么?
当然。
那么如果这些接口中有重复的方法名称呢?
这种情况中你可以决定如何实现。
当然需要特别得小心。
但是在编译环节是没有问题的。
接口和抽象类的区别是什么?
接口中所有方法必须是抽象的,并且不能指定方法的访问修饰符。
抽象类中可以有方法的实现,也可以指定方法的访问修饰符。
如何区别重载方法?
不同的参数类型,不同的参数个数,不同的参数顺序。
const和readonly有什么区别?
const关键字用来声明编译时常量,readonly用来声明运行时常量。
System.String和System.StringBuilder有什么区别?
System.String是不可变的字符串。
System.StringBuilder存放了一个可变的字符串,并提供一些对这个字符串修改的方法。
内容摘要:
.net面试题系列文章第七篇,考察了一下知识点:
private、protected、public、internal修饰符,ASP.NET页面之间传递值的几种方式,override与重载的区别,.net的错误处理机制是什么,C#中接口和类的异同等
关键词:
.NET面试题面试题c#面试题
本文地址:
内容正文:
1.简述private、protected、public、internal修饰符的访问权限。
private:
私有成员,在类的内部才可以访问。
protected:
保护成员,该类内部和继承类中可以访问。
public:
公共成员,完全公开,没有访问限制。
internal:
在同一命名空间内可以访问。
2.写出一条Sql语句:
取出表A中第31到第40记录(SQLServer,以自动增长的ID作为主键,注意:
ID可能不是连续的。
)
selecttop10*fromAwhereidnotin(selecttop30idfromA)
解2:
selecttop10*fromAwhereid>(selectmax(id)from(selecttop30idfromA)asA)
3.列举ASP.NET页面之间传递值的几种方式。
1.使用QueryString,如....?
id=1;response.Redirect()....
2.使用Session变量
3.使用Server.Transfer
4.请说明在.net中常用的几种页面间传递参数的方法,并说出他们的优缺点。
session(viewstate)简单,但易丢失
application全局
cookie简单,但可能不支持,可能被伪造
inputttype="hidden"简单,可能被伪造
url参数简单,显示于地址栏,长度有限
数据库稳定,安全,但性能相对弱
5.override与重载的区别
Override用来重写父类的方法,重载使用相同名的方法或操作符拥有不同类型的参数
的错误处理机制是什么
.net错误处理机制采用try->catch->finally结构,发生错误时,层层上抛,直到找到匹配的Catch为止。
7.C#中接口和类的异同
接口和类都是类,不同的事,接口只包含方法或属性的声明,不包含具体实现方法的代码,接口可以实现多继承,而类只能是单继承,继承接口的类必须实现接口中声明的方法或属性。
接口主要定义一种规范,统一调用方法,在大型项目中接口正发挥日益重要的作用。
8.DataReader和DataSet的异同
DataReader和DataSet最大的区别在于,DataReader使用时始终占用SqlConnection,在线操作数据库..任何对SqlConnection的操作都会引发DataReader的异常..因为DataReader每次只在内存中加载一条数据,所以占用的内存是很小的..因为DataReader的特殊性和高性能.所以DataReader是只进的..你读了第一条后就不能再去读取第一条了..
DataSet则是将数据一次性加载在内存中.抛弃数据库连接..读取完毕即放弃数据库连接..因为DataSet将数据全部加载在内存中.所以比较消耗内存...但是确比DataReader要灵活..可以动态的添加行,列,数据.对数据库进行回传更新操作...
9.在c#中using和new这两个关键字有什么意义,请写出你所知道的意义?
Using引入一个名子空间,或在使用了一个对像后自动调用其IDespose,New实例化一个对像,或修饰一个方法,表此方法完全重写此方法
10.在下面的例子里
usingSystem;
classA
{
publicA(){
PrintFields();
}
publicvirtualvoidPrintFields(){}
}
classB:
A
{
intx=1;
inty;
publicB(){
y=-1;
}
publicoverridevoidPrintFields(){
Console.WriteLine("x={0},y={1}",x,y);
}
当使用newB()创建B的实例时,产生什么输出?
X=1,Y=0
二、C#部分*
13.以下哪些可以作为接口成员?
(多选)(ABDE)
A.方法B.属性C.字段D.事件E.索引器
F.构造函数G.析构函数
14.以下关于ref和out的描述哪些项是正确的?
(多选)(ACD)
A.使用ref参数,传递到ref参数的参数必须最先初始化。
B.使用out参数,传递到out参数的参数必须最先初始化。
C.使用ref参数,必须将参数作为ref参数显式传递到方法。
D.使用out参数,必须将参数作为out参数显式传递到方法。
15.“访问范围限定于此程序或那些由它所属的类派生的类型”是对以下哪个成员可访问性含义的正确描述?
(B)
A.publicB.protectedC.internalD.protectedinternal
16.classClass1
{
privatestaticintcount=0;
staticClass1()
{
count++;
}
publicClass1()
{
count++;
}
}
Class1o1=newClass1();
Class1o2=newClass1();
请问,o1.Count的值是多少?
(C)
A.1B.2C.3D.4
17.abstractclassBaseClass
{
publicvirtualvoidMethodA()
{
}
publicvirtualvoidMethodB()
{
}
}
classClass1:
BaseClass
{
publicvoidMethodA(stringarg)
{
}
publicoverridevoidMethodB()
{
}
}
classClass2:
Class1
{
newpublicvoidMethodB()
{
}
}
classMainClass
{
publicstaticvoidMain(string[]args)
{
Class2o=newClass2();
Console.WriteLine(o.MethodA());
}
}
请问,o.MethodA调用的是:
(A)
A.BaseClass.MethodAB.Class2.MethodA
C.Class1.MethodAD.都不是
二编写SQL语句(5分/题)50
1)创建一张学生表,包含以下信息,学号,姓名,年龄,性别,家庭住址,联系电话
Createtablestu(学号int,
姓名varchar(8),
年龄int,
性别varchar(4),
家庭地址varchar(50),
联系电话int
);
2)修改学生表的结构,添加一列信息,学历
Altertablestuadd学历varchar(6);
3)修改学生表的结构,删除一列信息,家庭住址
Altertablestudropcolumn家庭地址
4)向学生表添加如下信息:
学号姓名年龄性别联系电话学历
1A22男123456小学
2B21男119中学
3C23男110高中
4D18女114大学
Insertintostuvalues(1,’A’,22,’男’,123456,’小学’)
Insertintostuvalues(2,’B’,21,’男’,119,’中学’)
Insertintostuvalues(3,’C’,23,’男’,110,’高中’)
Insertintostuvalues(4,’D’,18,’女’,114,’大学’)
5)修改学生表的数据,将电话号码以11开头的学员的学历改为“大专”
Updatestuset学历=’大专’where联系电话like‘11%’
6)删除学生表的数据,姓名以C开头,性别为‘男’的记录删除
Delectfromstuwhere性别=’男’and姓名like‘c%’
7)查询学生表的数据,将所有年龄小于22岁的,学历为“大专”的,学生的姓名和学号示出来
Select姓名,学号fromstuwhere年龄<22and学历=’大专’
8)查询学生表的数据,查询所有信息,列出前25%的记录
Selecttop25percent*fromstu
9)查询出所有学生的姓名,性别,年龄降序排列
Select姓名,性别fromstuorderby年龄desc
10)按照性别分组查询所有的平均年龄
Selectavg(年龄)fromstugroupby性别
已知一个表的结构为:
2姓名科目成绩
3张三语文20
4张三数学30
5张三英语50
6李四语文70
7李四数学60
8李四英语90
9怎样通过select语句把他变成以下结构:
10姓名语文数学英语
11张三203050
12李四706090
selectA.姓名,A.科目as语文,B.科目as数学,C.科目as英语
fromstudentA,studentB,studentC
whereA.姓名=B.姓名andB.姓名=C.姓名
andA.科目='语文'andB.科目='数学'
andC.科目='英语'
三填空(3分/题)36
1)索引分为__聚集索引___和__非聚集索引__在一张表上最多可以创建1个聚集索引_索引。
但是可以创建_249个非聚集索引索引。
2)系统存储过程_sp-helptext__是用来显示规则,默认值,未加密的存储过程,用户定义函数,触发或视图的文本
3)事务开始:
beginTransction
提交事务:
commitTransction
回滚事务:
rollbackTransction
四问答题(5分/题)60
1)数据库包含哪些那几种后缀名的文件必须,这些文件分别存放在什么的信息?
主要数据文件(.mdf)包含数据用户收集的信息,还有数据库其他相关的信息,
日志数据文件(.ndf)存放用户对数据库的增删改查的信息,用于备份恢复使用
2)TRUNCATETABLE命令是什么含义?
和Deletefrom表名有什么区?
TRUNCATETABLE:
提供了一种删除表中所有记录的快速方法
Deletefrom表名:
可以删除表的一个或多条记录
3)说出以下聚合数的含义:
avg,sum,max,min,count,count(*)
AVG:
求平均值
SUM:
求和
MAX:
求最大值
MIN:
求最小值
COUNT(*):
返回所有行数
COUNT返回满足指定条件的记录值
4)innerjoin是什么意思?
作用是什么?
写出基本语法结构
INNERJOIN内联接,用于返回两个表中要查询的列数据通信
Select*from表名1innerjoin表名2on条件表达式
5)左向外联接,右向外联接,全联接的关健字如何写?
Leftouterjoin左向外联接
Rightouterjoin右向外联接
Fullouterjoin全联接
6)子查询分为几类,说明相互之间的别
了查询分三种基本子查询:
1.使用in查询返回一列或更多值
2.比较运算符,返回单个值勤做为外查询的参数
3.用exists查询时相当于进行一次数据测试
7)实现实体完整性,实现域完整性,实现完整性(引用完整性),实现自定义完整性分别使用什么手段?
实现实体完整性:
主键约束唯一约束标识列
实现域完整性:
默认值约束检查约束非空属性
引和完整性:
外键引用
8)视图可以更新吗?
会影响到实际表吗?
视图是可以更新的,视图只是基于基本表上的虚拟表,对视图的更新会直接影响到实际表
9)谈谈这样几个角色,dbo,Sysadminpublic
Dbo:
是数据库的拥有者,对数据库拥有所有操作的权限
Sysadmin:
可以对SQLSERVER执行任何活动
Public:
自动创建的,能捕获数据库中用户的所有默认权限
10)何为动态游标?
何为静态游标?
动态游标与静态游标相对,反映结果集中所做的所有更改,
静态游标的结果集在游标打开时,建立在tempdb中,总按照游标打开
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- c# 试题