C#整理面试试题分类以及sql数据库(含答案)

拥有回忆 提交于 2019-12-09 22:45:17

1C# property attribute的区别,他们各有什么用处,这种机制的好处在哪里?

propertyattribute汉语都称之为属性。不过property是指类向外提供的数据区域。而attribute则是描述对象在编译时或运行时属性的。这两者是有本质区别的。
2 .
列举ASP.NET 页面之间传递值的几种方式。

1.使用QueryString, ....?id=1; response. Redirect()....

2.使用Session变量

3.使用Server.Transfer

3. 一列数的规则如下: 112358132134...... 求第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与重载的区别
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 构架下remotingwebservice两项技术的理解以及实际中的应用。
服务器端向客户端发送一个进程编号,一个程序域编号,以确定对象的位置。

11.公司要求开发一个继承System.Windows.Forms.ListView类的组件,要求达到以下的特殊功能:点击

答:根据点击的列头,包该列的ID取出,按照该ID排序后,在给绑定到ListView中。

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

13.abstract classinterface有什么区别?
答:

声明方法的存在而不去实现它的类被叫做抽象类(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 serverSQL Server数据库的方式存储Session不过这种方式比较慢,而且无法捕获SessionEND事件。

17.进程和线程的区别?
答:进程是系统进行资源分配和调度的单位;线程是CPU调度和分派的单位,一个进程可以有多个线程,这些线程共享这个进程的资源。
18.
请说明在.net中常用的几种页面间传递参数的方法,并说出他们的优缺点。
答:session(viewstate) 简单,但易丢失

application 全局 cookie 简单,但可能不支持,可能被伪造

input  type="hidden" 简单,可能被伪造

url参数 简单,显示于地址栏,长度有限

数据库 稳定,安全,但性能相对弱

 

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

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

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

22.ADO.net中常用的对象有哪些?分别描述一下。
答:Connection 数据库连接对象

Command 数据库命令

DataReader 数据读取器

DataSet 数据集

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

<script language=javascript>

setTimeout('window.close();',3000);

function show()

{

if (window.event.button == 1)

{

alert("");

}

else if (window.event.button == 2)

{

alert("");

}

}

</script>

 

数据库面试题

 

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
//创建临时表 2013-06-24 liangjw

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创建一张用户临时表和系统临时表,里面包含两个字段IDIDValues,类型都是int型,并解释下两者的区别?
------------------------------------------
用户临时表:create table #xx(ID int, IDValues int)

系统临时表:create table ##xx(ID int, IDValues int)

区别:

用户临时表只对创建这个表的用户的Session可见,对其他进程是不可见的.

当创建它的进程消失时这个临时表就自动删除.

全局临时表对整个SQL Server实例都可见,但是所有访问它的Session都消失的时候,它也自动删除.

8.一个表中的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


易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!