博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
asp.net c# 常见面试试题总结汇总(含答案)
阅读量:6576 次
发布时间:2019-06-24

本文共 5540 字,大约阅读时间需要 18 分钟。

hot3.png

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与重载的区别 
 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分钟后自动关闭页面。

<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创建一张用户临时表和系统临时表,里面包含两个字段ID和IDValues,类型都是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

转载于:https://my.oschina.net/liangjw0504/blog/151725

你可能感兴趣的文章
Craking the Interview-1
查看>>
POJ 3468 A Simple Problem with Integers(线段树,区间更新,区间求和)
查看>>
CCF NOI1150 确定进制
查看>>
SpringBoot实战总汇--详解
查看>>
2018年7月1日笔记
查看>>
尝试使用iReport4.7(基于Ubuntu Desktop 12.04 LTS)
查看>>
安装GIT(基于Ubuntu Desktop 12.04 LTS)
查看>>
动态规划:金矿模型
查看>>
子元素应该margin-top为何会影响父元素【转】
查看>>
AJAX 状态值(readyState)与状态码(status)详解
查看>>
BZOJ3668:[NOI2014]起床困难综合症(贪心)
查看>>
jQuery 中bind(),live(),delegate(),on() 区别
查看>>
C++编程中const和#define的区别
查看>>
LightOJ 1245(Harmonic Number (II))
查看>>
小知识记录
查看>>
109. Convert Sorted List to Binary Search Tree
查看>>
玩转HTML5移动页面
查看>>
Please review your Gradle project setup in the android/ folde
查看>>
css3 animate 和关键帧 @-webkit-keyframes
查看>>
文字链接颜色设置
查看>>