asp.net c# 常见面试试题总结汇总(含答案)

1、C#中 property 与 attribute的区别,他们各有什么用处,这种机制的好处在哪里? 
 property和attribute汉语都称之为属性。不过property是指类向外提供的数据区域。而attribute则是描述对象在编译时或运行时属性的。这两者是有本质区别的。 


2 .列举ASP.NET 页面之间传递值的几种方式。 
(1)使用QueryString, 如....?id=1; response. Redirect().... 
(2)使用Session变量。
(3)使用Server.Transfer 


3. 一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少, 用递归算法实现。

public class MainClass 
    { 
        //主函数调用输出低30的数值 
        public static void Main() 
        { 
            Console.WriteLine(Foo(30)); 
            Console.ReadLine(); 
        } 
        //方法封装,参数为第几个,求第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); 
            } 
        } 
    } 


4.C#中的委托是什么?事件是不是一种委托? 
委托可以把一个方法作为参数代入另一个方法。 
委托可以理解为指向一个函数的引用。事件是一种委托,是一种特殊的委托。


5.override(重写)与overload(重载)的区别。
override 与重载的区别:重载是方法的名称相同,参数或参数类型不同,进行多次重载以适应不同的需要;Override 是进行基类中函数的重写,为了适应需要。 


6.请编程遍历页面上所有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 ; 
   } 
} 


7.在下面的例子里:

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 


 8.什么是装箱和拆箱? 

答:从值类型接口转换到引用类型装箱。从引用类型转换到值类型拆箱。 
例如: 
装箱: int i=0; Object obj=i; 
拆箱: int i=0; Object obj=i; 
int j=(int)obj; 


9.常用的调用WebService的方法有哪些? 
(1)使用WSDL.exe命令行工具。 
(2)使用VS.NET中的Add Web Reference菜单选项。


10.简要谈一下您对微软.NET 构架下remoting和webservice两项技术的理解以及实际中的应用。
答:服务器端向客户端发送一个进程编号,一个程序域编号,以确定对象的位置。 


11.公司要求开发一个继承System.Windows.Forms.ListView类的组件,要求达到以下的特殊功能:点击 
 答:根据点击的列头,包该列的ID取出,按照该ID排序后,在给绑定到ListView中。 


12.能用foreach遍历访问的对象需要实现 ________________接口或声明________________方法的类型。 
 答:IEnumerable 、 GetEnumerator。 


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

 

14.sleep() 和 wait() 有什么区别?
答:sleep()方法是使线程停止一段时间的方法。在sleep 时间间隔期满后,线程不一定立即恢复执行。这是因为在那个时刻,其它线程可能正在运行而且没有被调度为放弃执行,除非:(a)“醒来”的线程具有更高的优先级;(b)正在运行的线程因为其它原因而阻塞。
wait()是线程交互时,如果线程对一个同步对象x 发出一个wait()调用,该线程会暂停执行,被调对象进入等待状态,直到被唤醒或等待时间到。


15.如何处理几十万条并发数据?
 答:用存储过程或事务。取得最大标识的时候同时更新,注意主键不是自增量方式这种方法并发的时候是不会有重复主键的,取得最大标识要有一个存储过程来获取。

 

16.Session有什么重大BUG,微软提出了什么方法加以解决?
 答:是iis中由于有进程回收机制,系统繁忙的话Session会丢失,可以用Sate server或SQL Server数据库的方式存储Session不过这种方式比较慢,而且无法捕获Session的END事件。


17.进程和线程的区别。

答:进程是系统进行资源分配和调度的单位;线程是CPU调度和分派的单位,一个进程可以有多个线程,这些线程共享这个进程的资源。


18.请说明在.net中常用的几种页面间传递参数的方法,并说出他们的优缺点。
 答:session(viewstate) 简单,但易丢失。
application 全局 cookie 简单,但可能不支持,可能被伪造。
input  type="hidden" 简单,可能被伪造。
url参数 简单,显示于地址栏,长度有限。
数据库 稳定,安全,但性能相对弱。

 

19.DataReader与Dataset有什么区别?
答:一个是只能向前的只读游标,一个是内存中的表。


20.软件开发过程一般有几个阶段?每个阶段的作用?
答:需求分析,架构设计,代码编写,QA(质量保证),部署。


21.什么叫做SQL注入,如何防止?请举例说明。
答:利用sql关键字对网站进行攻击。过滤关键字'等。


22.ADO.net中常用的对象有哪些?分别描述一下。
 答:Connection 数据库连接对象
Command 数据库命令
DataReader 数据读取器
DataSet 数据集


23.写一个HTML页面,实现以下功能,左键点击页面时显示“您好”,右键点击时显示“禁止右键”。并在2分钟后自动关闭页面。

 

=================================================

数据库面试题

1.一道SQL语句面试题,关于 group by 表内容:
2005-05-09 胜
2005-05-09 胜
2005-05-09 负
2005-05-09 负
2005-05-10 胜
2005-05-10 负
2005-05-10 负
如果要生成下列结果, 该如何写sql语句?
              胜 负
2005-05-09 2 2
2005-05-10 1 2
//创建临时表
create table #tmp(rq varchar(10),shengfu nchar(1))

insert into #tmp values('2005-05-09','胜')
insert into #tmp values('2005-05-09','胜')
insert into #tmp values('2005-05-09','负')
insert into #tmp values('2005-05-09','负')
insert into #tmp values('2005-05-10','胜')
insert into #tmp values('2005-05-10','负')
insert into #tmp values('2005-05-10','负')

1)select rq, sum(case when shengfu='胜' then 1 else 0 end)'胜',sum(case when shengfu='负' then 1 else 0 end)'负' from #tmp group by rq

 

2. 表中有A B C三列,用SQL语句实现:当A列大于B列时选择A列否则选择B列,当B列大于C列时选择B列否则选择C列。
------------------------------------------
select (case when a>b then a else b end ),
 (case when b>c then b esle c end)
 from table_name

 

3.一个日期判断的sql语句?
 请取出tb_send表中日期(SendTime字段)为当天的所有记录?(SendTime字段为datetime型,包含日期与时间)

select * from tb where datediff(dd,SendTime,getdate())=0


4.有一张表,里面有3个字段:语文,数学,英语。其中有3条记录分别表示语文70分,数学80分,英语58分,请用一条sql语句查询出这三条记录并按以下条件显示出来(并写出您的思路):  
   大于或等于80表示优秀,大于或等于60表示及格,小于60分表示不及格。  
       显示格式:  
       语文              数学                英语  
       及格              优秀                不及格    
------------------------------------------
 select
 (case when 语文>=80 then '优秀'
         when 语文>=60 then '及格'
else '不及格') as 语文,
 (case when 数学>=80 then '优秀'
         when 数学>=60 then '及格'
else '不及格') as 数学,
 (case when 英语>=80 then '优秀'
         when 英语>=60 then '及格'
else '不及格') as 英语,
from table

 

5.在sqlserver2000中请用sql创建一张用户临时表和系统临时表,里面包含两个字段ID和IDValues,类型都是int型,并解释下两者的区别?
------------------------------------------
 用户临时表:create table #xx(ID int, IDValues int)
系统临时表:create table ##xx(ID int, IDValues int)
区别:
用户临时表只对创建这个表的用户的Session可见,对其他进程是不可见的。
当创建它的进程消失时这个临时表就自动删除。
全局临时表对整个SQL Server实例都可见,但是所有访问它的Session都消失的时候,它也自动删除。

 

6.一个表中的Id有多个记录,把所有这个id的记录查出来,并显示共有多少条记录数。

select id, Count(*) from tb group by id having count(*)>1
 select * from(select count(ID) as count from table group by ID)T where T.count>1

你可能感兴趣的:(ASP.NET,DotNet笔试面试题,SQL)