c#面试题.docx

上传人:b****7 文档编号:9658546 上传时间:2023-02-05 格式:DOCX 页数:145 大小:80.73KB
下载 相关 举报
c#面试题.docx_第1页
第1页 / 共145页
c#面试题.docx_第2页
第2页 / 共145页
c#面试题.docx_第3页
第3页 / 共145页
c#面试题.docx_第4页
第4页 / 共145页
c#面试题.docx_第5页
第5页 / 共145页
点击查看更多>>
下载资源
资源描述

c#面试题.docx

《c#面试题.docx》由会员分享,可在线阅读,更多相关《c#面试题.docx(145页珍藏版)》请在冰豆网上搜索。

c#面试题.docx

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模板 > 卡通动漫

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1