『壹』 .net面试问题
当然亮点是别人不会的,你会了,并使得项目更高效,楼主应该多了解一下更版高的技术,做权这一行的,天天都在学习。
我是做B/S的,以前做项目会根据需求分析来做相应的功能。比如在做功能大的CMS和商城系统的时候,我会用到ajax+ashx做无刷新分页和评论,MVC+三层,存储过程,缓存,URL重写,页面静态化。比如,在做到ajax别人用到了MS的updatapanel会导致页面样式丢失,ajax功能失效,我们可以通过单步调试理解代码执行过程,通过httpwatch深刻理解请求与响应的过程,这样就很容易找到问题所在。当然也要对底层要理解,像我做的B/S里就要求深刻理解页面的生命周期。通过Reflector这个反编译工具你会找到很多底层的代码。
面试嘛,一定要能侃,当然技术是来不了半点含糊的。夸夸其谈不是没有的,多看一些技术文章,到博客园看看你感兴趣的文章,一般就会侃了。嘿嘿~其实我没做过大项目……
『贰』 .net找工作要不要背面试题,两年.NET开发经验
我觉得要背。
你不知道你会碰到一个什么样的HR,所以多做准备也是好的。
还有就专是面试题一般来说会更属基础性,多做一点题的话能够找到自己平时做项目时没搞懂的东西。
项目不就是那样,很多东西你会用,但不见得了解技术核心。
还有,面试题得分高的话,起码会给你更大的被录用的概率吧。
祝好运。
『叁』 软件工程设计师 C#、ASP.NET开发面试一般都会笔试和面试哪些题目,谢谢
#, ASP.NET笔试题(1)
1. 简述 private、 protected、 public、 internal 修饰符的访问权限
答:
private : 私有成员, 在类的内部才可以访问。
protected : 保护成员,该类内部和继承类中可以访问。
public : 公共成员,完全公开,没有访问限制。
internal: 在同一命名空间内可以访问。
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
{
public static void Main()
{
Console.WriteLine(Foo(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. 如果在一个B/S结构的系统中需要传递变量值,但是又不能使用Session、Cookie、Application,您有几种方法进行处理?
答:this.Server.Transfer
7. 请编程遍历页面上所有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 ;
}
}
8. 请编程实现一个冒泡排序算法?
答:
int [] array = new int;
int temp = 0 ;
for (int i = 0 ; i < array.Length - 1 ; i++)
{
for (int j = i + 1 ; j < array.Length ; j++)
{
if (array[j] < array[i])
{
temp = array[i];
array[i] = array[j];
array[j] = temp ;
}
}
}
9. 描述一下C#中索引器的实现过程,是否只能根据数字进行索引?
答:不是。可以用任意类型。
10. 求以下表达式的值,写出您想到的一种或几种实现方法:1-2+3-4+……+m
答:
int Num = this.TextBox1.Text.ToString();
int Sum = 0;
for (int i = 0; i < Num + 1; i++)
{
if ((i % 2) == 1)
{
Sum += i;
}
else
{
Sum = Sum - I;
}
}
System.Console.WriteLine(Sum.ToString());
System.Console.ReadLine();
11. 用.net做B/S结构的系统,您是用几层结构来开发,每一层之间的关系以及为什么要这样分层?
答:一般为3层。数据访问层,业务层,表示层。数据访问层对数据库进行增删查改。业务层一般分为二层,业务表观层实现与表示层的沟通,业务规则层实现用户密码的安全等。表示层为了与用户交互例如用户添加表单。
优点: 分工明确,条理清晰,易于调试,而且具有可扩展性。
缺点: 增加成本。
12. 在下面的例子里
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
13. 什么叫应用程序域?
答:应用程序域可以理解为一种轻量级进程。起到安全的作用。占用资源小。
14. CTS、CLS、CLR分别作何解释?
答:CTS:通用语言系统。CLS:通用语言规范。CLR:公共语言运行库。
15. 什么是装箱和拆箱?
答:从值类型接口转换到引用类型装箱。从引用类型转换到值类型拆箱。
16. 什么是受管制的代码?
答:unsafe:非托管代码。不经过CLR运行。
17. 什么是强类型系统?
答:RTTI:类型识别系统。
18. .net中读写数据库需要用到那些类?他们的作用?
答:DataSet:数据存储器。
DataCommand:执行语句命令。
DataAdapter:数据的集合,用语填充。
19. ASP.net的身份验证方式有哪些?分别是什么原理?
答:10。Windwos(默认)用IIS...From(窗体)用帐户....Passport(密钥)
20. 什么是Code-Behind技术?
答:代码后植。
21. 在.net中,配件的意思是?
答:程序集。(中间语言,源数据,资源,装配清单)
22. 常用的调用WebService的方法有哪些?
答:1.使用WSDL.exe命令行工具。 2.使用VS.NET中的Add Web Reference菜单选项
23. .net Remoting 的工作原理是什么?
答:服务器端向客户端发送一个进程编号,一个程序域编号,以确定对象的位置。
24. 在C#中,string str = null 与 string str = " " 请尽量使用文字或图象说明其中的区别
答:string str = null 是不给他分配内存空间,而string str = "" 给它分配长度为空字符串的内存空间。
25. 请详述在dotnet中类(class)与结构(struct)的异同?
答:Class可以被实例化,属于引用类型,是分配在内存的堆上的,Struct属于值类型,是分配在内存的栈上的.
(1)、结构是值类型;
(2)、结构不支持继承;
(3)、结构不能定义默认的构造函数;
(4)、结构不能定义析构函数;
(5)、结构不能使用初始值设置域值
26. 根据委托(delegate)的知识,请完成以下用户控件中代码片段的填写:
namespace test
{
public delegate void OnDBOperate();
public class UserControlBase : System.Windows.Forms.UserControl
{
public event OnDBOperate OnNew;
privatevoidtoolBar_ButtonClick(objectsender,System.Windows.Forms.ToolBarButtonClickEventArgs e)
{
if(e.Button.Equals(BtnNew))
{
//请在以下补齐代码用来调用OnDBOperate委托签名的OnNew事件。
}
}
}
}
答:if( OnNew != null ) OnNew(this, e);
27. 分析以下代码,完成填空
string strTmp = "abcdefg某某某";
int i= System.Text.Encoding.Default.GetBytes(strTmp).Length;
int j= strTmp.Length;
以上代码执行完后,i=______ j=______
答:i=13,j=10
28. SQLSERVER服务器中,给定表 table1 中有两个字段 ID、LastUpdateDate,ID表示更新的事务号,LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号
答:Select ID FROM table1 Where LastUpdateDate = (Select MAX(LastUpdateDate) FROM table1)
29. 根据线程安全的相关知识,分析以下代码,当调用test方法时i>10时是否会引起死锁?并简要说明理由。
public void test(int i)
{
lock (this)
{
if (i > 10)
{
i--;
test(i);
}
}
}
答:不会发生死锁,(但有一点int是按值传递的,所以每次改变的都只是一个副本,因此不会出现死锁。但如果把int换做一个object,那么死锁会发生)
30. 简要谈一下您对微软.NET 构架下remoting和webservice两项技术的理解以及实际中的应用。
答:WS主要是可利用HTTP,穿透防火墙。而Remoting可以利用TCP/IP,二进制传送提高效率。
31. 公司要求开发一个继承System.Windows.Forms.ListView类的组件,要求达到以下的特殊功能:点击ListView各列列头时,能按照点击列的每行值进行重排视图中的所有行 (排序的方式如DataGrid相似)。根据您的知识,请简要谈一下您的思路
答:根据点击的列头,包该列的ID取出,按照该ID排序后,在给绑定到ListView中。
32. 给定以下XML文件,完成算法流程图
<FileSystem>
<DriverC>
<Dir DirName="MSDOS622">
<File FileName ="Command.com"></File>
</Dir>
<File FileName ="MSDOS.SYS"></File>
<File FileName ="IO.SYS"></File>
</DriverC>
</FileSystem>
请画出遍历所有文件名(FileName)流程图(请使用递归算法)。
答:
void FindFile( Directory d )
{
FileOrFolders = d.GetFileOrFolders();
foreach( FileOrFolder fof in FileOrFolders )
{
if( fof is File )
You Found a file;
else if ( fof is Directory )
FindFile( fof );
}
}
33. 写出一条Sql语句:取出表A中第31到第40记录(SQLServer,以自动增长的ID作为主键,注意:ID可能不是连续的。
答:解1: select top 10 * from A where id not in (select top 30 id from A)
解2: select top 10 * from A where id > (select max(id) from (select top 30 id from A )as A)
34. 面向对象的语言具有_______性、________性、_______性
答:封装、继承、多态。
35. 能用foreach遍历访问的对象需要实现 ____________接口或声明____________方法的类型。
答:IEnumerable 、 GetEnumerator。
36. GC是什么? 为什么要有GC?
答:GC是垃圾收集器。程序员不用担心内存管理,因为垃圾收集器会自动进行管理。要请求垃圾收集,可以调用下面的方法之一: System.gc() Runtime.getRuntime().gc()
37. String s = new String("xyz");创建了几个String Object?
答:两个对象,一个是“xyx”,一个是指向“xyx”的引用对象s。
38. abstract class和interface有什么区别?
答:
声明方法的存在而不去实现它的类被叫做抽象类(abstract class),它用于要创建一个体现某些基本行为的类,并为该类声明方法,但不能在该类中实现该类的情况。不能创建abstract 类的实例。然而可以创建一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态方法。Abstract 类的子类为它们父类中的所有抽象方法提供实现,否则它们也是抽象类为。取而代之,在子类中实现该方法。知道其行为的其它类可以在类中实现这些方法。
接口(interface)是抽象类的变体。在接口中,所有方法都是抽象的。多继承性可通过实现这样的接口而获得。接口中的所有方法都是抽象的,没有一个有程序体。接口只可以定义static final成员变量。接口的实现与子类相似,除了该实现类不能从接口定义中继承行为。当类实现特殊接口时,它定义(即将程序体给予)所有这种接口的方法。然后,它可以在实现了该接口的类的任何对象上调用接口的方法。由于有抽象类,它允许使用接口名作为引用变量的类型。通常的动态联编将生效。引用可以转换到接口类型或从接口类型转换,instanceof 运算符可以用来决定某对象的类是否实现了接口。
39. 启动一个线程是用run()还是start()?
答:启动一个线程是调用start()方法,使线程所代表的虚拟处理机处于可运行状态,这意味着它可以由JVM调度并执行。这并不意味着线程就会立即运行。run()方法可以产生必须退出的标志来停止一个线程。
40. 接口是否可继承接口? 抽象类是否可实现(implements)接口? 抽象类是否可继承实体类(concrete class)?
答:接口可以继承接口。抽象类可以实现(implements)接口,抽象类是否可继承实体类,但前提是实体类必须有明确的构造函数。
41. 构造器Constructor是否可被override?
答:构造器Constructor不能被继承,因此不能重写Overriding,但可以被重载Overloading。
42. 是否可以继承String类?
答:String类是final类故不可以继承。
43. try{ }里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后?
答:会执行,在return前执行。
44. 两个对象值相同(x.equals(y) == true),但却可有不同的hash code,这句话对不对?
答:不对,有相同的hash code。
45. swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
答:switch(expr1)中,expr1是一个整数表达式。因此传递给 switch 和 case 语句的参数应该是 int、 short、 char 或者 byte。long,string 都不能作用于swtich。
47. 当一个线程进入一个对象的一个synchronized方法后,其它线程是否可进入此对象的其它方法?
不能,一个对象的一个synchronized方法只能由一个线程访问。
48. abstract的method是否可同时是static,是否可同时是native,是否可同时是synchronized?
答:都不能。
49. List, Set, Map是否继承自Collection接口?
答:List,Set是Map不是
50. Set里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用==还是equals()? 它们有何区别?
答:Set里的元素是不能重复的,那么用iterator()方法来区分重复与否。equals()是判读两个Set是否相等。
equals()和==方法决定引用值是否指向同一对象equals()在类中被覆盖,为的是当两个分离的对象的内容和类型相配的话,返回真值。
51. 数组有没有length()这个方法? String有没有length()这个方法?
答:数组没有length()这个方法,有length的属性。String有有length()这个方法。
52. sleep() 和 wait() 有什么区别?
答:sleep()方法是使线程停止一段时间的方法。在sleep 时间间隔期满后,线程不一定立即恢复执行。这是因为在那个时刻,其它线程可能正在运行而且没有被调度为放弃执行,除非(a)“醒来”的线程具有更高的优先级
(b)正在运行的线程因为其它原因而阻塞。
wait()是线程交互时,如果线程对一个同步对象x 发出一个wait()调用,该线程会暂停执行,被调对象进入等待状态,直到被唤醒或等待时间到。
54. 谈谈final, finally, finalize的区别
答:
final—修饰符(关键字)如果一个类被声明为final,意味着它不能再派生出新的子类,不能作为父类被继承。因此 一个类不能既被声明为 abstract的,又被声明为final的。将变量或方法声明为final,可以保证它们在使用中 不被改变。被声明为final的变量必须在声明时给定初值,而在以后的引用中只能读取,不可修改。被声明为 final的方法也同样只能使用,不能重载
finally—再异常处理时提供 finally 块来执行任何清除操作。如果抛出一个异常,那么相匹配的 catch 子句就会 执行,然后控制就会进入 finally 块(如果有的话)。
finalize—方法名。Java 技术允许使用 finalize() 方法在垃圾收集器将对象从内存中清除出去之前做必要的清理 工作。这个方法是由垃圾收集器在确定这个对象没有被引用时对这个对象调用的。它是在 Object 类中定义的 ,因此所有的类都继承了它。子类覆盖 finalize() 方法以整理系统资源或者执行其他清理工作。finalize() 方法是在垃圾收集器删除对象之前对这个对象调用的。
55. 如何处理几十万条并发数据?
答:用存储过程或事务。取得最大标识的时候同时更新..注意主键不是自增量方式这种方法并发的时候是不会有重复主键的..取得最大标识要有一个存储过程来获取.
56. Session有什么重大BUG,微软提出了什么方法加以解决?
答:是iis中由于有进程回收机制,系统繁忙的话Session会丢失,可以用Sate server或SQL Server数据库的方式存储Session不过这种方式比较慢,而且无法捕获Session的END事件。
57. 进程和线程的区别?
答:进程是系统进行资源分配和调度的单位;线程是CPU调度和分派的单位,一个进程可以有多个线程,这些线程共享这个进程的资源。线程(Thread)与进程(Process)二者都定义了某种边界,不同的是进程定义的是应用程序与应用程序之间的边界,不同的进程之间不能共享代码和数据空间,而线程定义的是代码执行堆栈和执行上下文的边界。一个进程可以包括若干个线程,同时创建多个线程来完成某项任务,便是多线程。而同一进程中的不同线程共享代码和数据空间。用一个比喻来说,如果一个家庭代表一个进程,在家庭内部,各个成员就是线程,家庭中的每个成员都有义务对家庭的财富进行积累,同时也有权利对家庭财富进行消费,当面对一个任务的时候,家庭也可以派出几个成员来协同完成,而家庭之外的人则没有办法直接消费不属于自己家庭的财产。
58. 堆和栈的区别?
答:栈:由编译器自动分配、释放。在函数体中定义的变量通常在栈上。
堆:一般由程序员分配释放。用new、malloc等分配内存函数分配得到的就是在堆上。
59. 成员变量和成员函数前加static的作用?
答:它们被称为常成员变量和常成员函数,又称为类成员变量和类成员函数。分别用来反映类的状态。比如类成员变量可以用来统计类实例的数量,类成员函数负责这种统计的动作。
60. ASP.NET与ASP相比,主要有哪些进步?
答:asp解释形,aspx编译型,性能提高,有利于保护源码。
『肆』 帮忙给弄一些asp.net工程师面试时的笔试题。谢谢
1、简述private,protected,public,internal修饰符的访问权限
1.private私有的,public公共的,protected受保护的
internal内部权限的
private : 私有成员, 在类的内部才可以访问。
protected : 保护成员,该类内部和继承类中可以访问。
public : 公共成员,完全公开,没有访问限制。
internal: 在同一命名空间内可以访问。
2.请编程遍历页面上所有TextBox控件并给它赋值为stringEmpty
前台的代码:
foreach (Control txtobj in this.Page.Controls)
{
if (txtobj.GetType().Name == "TextBox")
{
// ((TextBox)txtobj).Text = "";//这是第一种方法赋值,第二种在下面
TextBox tb = new TextBox();
tb = (TextBox)this.FindControl(txtobj.ID); nbsp;
tb.Text = string.Empty;
}
后台代码:
foreach(Control ctl in this.Controls)
{
if(ctl is TextBox){
(ctl as TextBox).Text = string.Empty;
}}
}
4.ASP.net的身份验证方法有哪些?分别是什么原因?
1、 Windows 身份验证提供程序
提供有关怎么将 Windows 身份验证与 Microsoft Internet 信息服务 (IIS) 身份验证结合用来确保 ASP.NET 应用程序安全的信息。
2、 Forms 身份验证提供程序
提供有关怎么用您自己的代码创建应用程序特定的登陆窗体并执行身份验证的信息。用 Forms 身份验证的一种简便方法是用 ASP.NET 成员资格和 ASP.NET 登陆控件,它们一起提供了一种只需少量或无需代码就可以收集、验证和管理用户凭据的方法。有关更多信息,请
参见用成员资格管理用户和 ASP.NET 登陆控件概述。
3、 Passport 身份验证提供程序
提供有关由 Microsoft 提供的集中身份验证服务的信息,该服务为成员站点提供单一登陆和核心配置文件服务。
5.在C#中string str=null 与string str=“”请尽量使用文字说明其中的区别
string str=null;不会开辟内存给str,string str="";会开辟一块内存,值为空字符串
6.try{}里有一个return语句,那么紧跟在这个try后的finaliy{}里的code会不会被执行,什么时候被执行。在return前还是后?
finally()代码块 无论什么情况都会被执行,在return之后。
下面是个测试程序public class FinallyTest {
public static void main(String[] args) {
System.out.println(new FinallyTest().test()); }
static int test() {
int x = 1;
try{
x++;
return x;
}finally{
++x;
} }}
肯定执行了你在finally里加一条输出语句你就知道了但结果为什么会是2呢?在try语句中,在执行return语句时,要返回的结果已经准备好了,
就在此时,程序转到finally执行了。在转去之前,try中先把要返回的结果存放到不同于a的局部变量中去,
执行完finally之后,在从中取出返回结果,因此,即使finally中对变量a进行了改变,但是不会影响返回结果。
它应该使用栈保存返回值。
7.ASP.NET与ASP相比,主要有哪些进步?
1.网页内容与程序代码分离2.多语言支持3.执行效率更高4.面向对象的特性5.运行在.net平台上
8.请说明在.net中常用的几种页面间传递参数的方法。并说出他们的优缺点。
QueryString此方法的优点是简单、方便,缺点是能传递的数据量少,而且不能传递对象。
Session该 方 法 的 特点是 :
(1)用户数据存储在服务器端;
(2)ASP.NET 中的Session 对象也可以不依赖Cookie 而正常工作;
(3)可以直接存储对象,且无大小限制;
(4)有效期与用户的活动时间有关,具体为用户活动时间+自定义延迟时间。该方法的缺点是:由于Web 应用程序对每个用户都会生成 Session 变量,因此它会随着用户数量的增多而加重服务器的负担。如果数据量比较小,Sessionss 对象是保存只需要在当前对话中保持
的特定数据的极好位置。
cookie该方法的缺点是:并非所有的浏览器都支持Cookie;用户可以禁用和删除它;信息采用明文保存,安全性差。当特定的用户需要特定的数据片,并且需要把数据在某个可变的时段中保持的时候,Cookie 就非常方便,存在于客户端,不占用服务器资源。
static静态变量,可能直接通类名来调用,优点是如果善加利用,则可以有效提高数据传递效率,缺点是如果滥用,则会导致用户或页面间数据紊乱,造成极大的隐患。
9.DataReader与Dataset有什么区别?
dataset表示一个数据集,是数据在内存中的缓存。 可以包括多个表
DatSet 连接数据库时是非面向连接的。把表全部读到Sql中的缓冲池,并断开于数据库的连接
datareader 连接数据库时是面向连接的。读表时,只能向前读取,读完数据后有用户决定是否断开连接。
10.什么叫做SQL注入,在.net 中如何防止?请举例说明
sql注入大都是SQL语法里的一些组合,通过执行SQL语句进而执行攻击者所要的操作,其主要原因是程序没有细致地过滤用户输入的数据,致使非法数据侵入系统。
.net中可以使用带参数的sql语句或者直接调用存储过程可以有效的防止sql注入攻击
还可以对用户的输入进行校验,可以通过正则表达式,或限制长度;对单引号和
双"-"进行转换等。
『伍』 .NET面试技术问题
40 post能得到的数据比来get要大
39 静态源
38,34 string 不可改变大小,BUFFER可以,
buffer 提供的方法少很多,但是绝对高效,对多字串操作请用BUFFER
35,5, 三个区别。构造函数有区别,struct是值类型,CLASS是引用类型,类可以继承,结构不可以
33 重载看参数个数和参数类型
28 2个
29 object 重载同时存在,覆写旧的那个就没了。
21 委托是方法的签名,事件是一种多播委托
26 所有子类中可访问
7 虚拟
『陆』 好心人 提供一份用友net软件工程师的笔试、面试题
用友笔试题目NET面试题专栏 (部分)
用友, 笔试, NET, 专栏, 题目
1、 面向对象的语言具有___封装__性、___继承__性、___多态_性。
2、 能用foreach遍历访问的对象需要实现 __ IEnumerable __接口或声明__GetEnumerator __方法的类型。
3、 以下叙述正确的是:
A. 接口中可以有虚方法。 B. 一个类可以实现多个接口。
C. 接口不能被实例化。 D. 接口中可以包含已实现的方法。
4、 简述 private、 protected、 public、 internal 修饰符的访问权限。
Private 私有成员:只有本类内部可以访问
Protected 受保护成员:只有本类和本类的子类可以访问
Public 公有成员:完全公开,没有访问限制
Internal :在同一命名空间下可以访问
5、写出一条Sql语句: 取出表A中第31到第40记录(SQLServer, 以自动增长的ID作为主键, 注意:ID可能不是连续的。)
select top 10 * from A where id not in (select top 30 id from A)
5、 DataReader与DataSet有什么区别?
(1)、dataset表示一个数据集,是数据在内存中的缓存。 可以包括多个表;
(2)、dataset连接数据库时是非面向连接的。把表全部读到Sql中的缓冲池,并断开于数据库的连接
(3)、datareader 连接数据库时是面向连接的。读表时,只能向前读取,读完数据后有用户决定是否断开连接。
6、 简述什么是装箱?
把一个值类型的数据转换为引用类型的数据的过程叫装箱。
7、 下列选项中,(c)是引用类型。
a) enum类型 b) struct类型
c) string类型 d) int类型
8、 一个数据库中的一个表中有 year 、salary这两个字段,原表中数据如原表,请用SQL查询出结果显示的数据:
原表中数据:
year salary
—————————————–
2000 1000
2001 2000
2002 3000
2003 4000
结果表中数据:
year salary
——————————————
2000 1000
2001 3000
2002 6000
2003 10000
写出SQL语句如下:
create table test([year] int ,salary int)
insert test(year,salary) values(2000,1000)
insert test(year,salary) values(2001,2000)
insert test(year,salary) values(2002,3000)
insert test(year,salary) values(2003,4000)
select t1.year, (select sum(salary) from test as t2 where t2.year<=t1.year) as salary from test t1 order by year asc
9、运行下列代码:
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()时,输出的结果是:x=?;y=?
x=1;y=0
10、用C#写出singleton(单例)模式的例子?
<一>、我对单例模式的理解说明如下:
单例模式的意图是:保证一个类仅有一个实例,并提供一个访问它的全局访问点。
它的工作原理是:用一个特殊的方法来实例化所需的对象。其中最关键的就是这个特殊的方法:
(1)、调用这个方法时,检查对象是否已经实例化。如果已经实例化,该方法仅返回对该对象的一个引用。如果尚未实例化,该方法就实例化该对象并返回对此新实例的一个引用。
(2)、为了确保这是实例化此类型对象的唯一方法,我将这个类的构造函数定义为保护的或者私有的。
<二>、详细实例如下:
using System;
class Singleton
{
private static Singleton instance;
protected Singleton() {}
public static Singleton Instance()
{
if( instance == null )
instance = new Singleton();
return instance;
}
}
public class Client
{
public static void Main()
{
Singleton s1 = Singleton.Instance();
Singleton s2 = Singleton.Instance();
if( s1 == s2 )
Console.WriteLine( “The same instance” );
}
}
『柒』 .net 面试题目
1, 请你说说.NET中类和结构的区别? 答:结构和类具有大体的语法,但是结构受到的限制比类要多。结构不能申明有默认的构造函数,为 结构的副本是又编译器创建和销毁的,所以不需要默认的构造函数和析构函数。结构是值类型,所以对结 构变量所做的改变不会影响其的原值,而类是应用类型,改变其变量的值会改变其原值。申明结构用 Struck关键字,申明类用class关键字,向方法传递结构是时是通过值传递的,而不是通过引用。与类不同 ,结构的实例化可以不使用New关键字。类可以实现接口。 2, 死锁的必要条件?怎么克服? 答:系统的资源不足,进程的推进的顺序不合适,资源分配不当,一个资源每次只能被一个进程使用 ,一个资源请求资源时,而此时这个资源已阻塞,对已获得资源不放,进程获得资源时,未使用完前,不 能强行剥夺。 3, 接口是否可以继承接口?抽象类是否可以实现接口?抽象类是否可以继承实体类? 答:接口是可以继承接口的,抽象类是可以实现接口的,抽象类可以继承实体类,但是有个条件,条 件是,实体类必须要有明确的构造函数。 4, 构造器Constructor是否可以被继承?是否可以被Override? 答:Constructor不可以被继承,因此不能被重写(Overriding),但可以被重载(Overloading). 5,是否可以继承String类? 答:因为String类是final类所以不可以继承string类。 5, 当一个线程进入一个对象的方法后,其它线程是否可以进入该对象的方法? 答:不可以,一个对象的方法只能由一个线程访问。 6, 用最有效的方法算出等已8对于几? 答:2<<3. 7,C#是否可以对内存直接进行操作? 答:这个问题比较难回答,也是个很大的问题。但是可以这样问答。C#是可以对内存进行直接操作的 ,虽然很少用到指针,但是C#是可以使用指针的,在用的时候需要在前边加unsafe,,在.net中使用了垃圾 回收机制(GC)功能,它替代了程序员,不过在C#中不可以直接使用finalize方法,而是在析构函数中调 用基类的finalize()方法。 7, 数组有没有Length()这和方法?string有没有这个方法? 答:数组中没有这个方法,但有这个属性,string中有这个方法。 8, Error和Exception有是区别? 答:error表示恢复不是不可能,但是很困难,exception表示一种实际或实现问题,它表示程序运行 正常不可以发生的。 9,谈谈final,finally,finallize的区别? 答:final用于申明属性,方法和类,表示属性不可变,方法不可以被覆盖,类不可以被继承。 Finally是异常处理语句结构中,表示总是执行的部分。 Finallize表示是object类一个方法,在垃圾回收机制中执行的时候会被调用被回收对象的方法。 10,HashMap和Hashtable区别? 答:HashMap是Hashtable的轻量级实现,非线程安全的实现他们都实现了map接口,主要区别是 HashMap键值可以为空null,效率可以高于Hashtable。 11,Collection和Collections的区别? 答:Collection是集合类的上级接口,Collections是针对集合类的一个帮助类,它提供一系列静态方 法来实现对各种集合的搜索,排序,线程安全化操作。 12,C#中委托是什么?事件是不是一种委托? 答:委托是一种安全的类似与函数指针,但是她比指针要安全的多,它可以把方法作为一个参数传递 给另一个方法,可以理解为指向函数的引用。事件是一种消息机制,它是一种委托,委托不带方法体。 13,Override, Overload,的区别? 答:Override是重写的意思,它表示重写基类的方法,而且方法的名称,返回类型,参数类型,参数 个数要与基类相同。 Overload是重载是意思,它也表示重写基类的方法,但是只要方法名相同,别的可以不同。 14,在一个BS结构中需要传递变量值时,不能使用session,coolke,application,你有几中方法? 答:this.server.Transfer,Querystring. 15,C#种索引器实现过程,是否只能根据数字索引? 答:不是的,可以是任意类型。 15,C#种索引器实现过程,是否只能根据数字索引? 答:不是的,可以是任意类型。 16,New有种用法? 答:有3种,第一种是,实例化如:New Class() 第二种是,public new 隐藏基类的方法 第三种是,在泛型类申明中的任何类型参数都必须有公共的无参构造函数。 17,任何把一个Array复制到Arraylist中? 答:Foreach (object o in Array), ArrayList.Add (0) 等有好多中种方法。自己想。 18,概述反射和序列化? 答:反射:要给发射下一个定义还是比较难的,这里先说说我的理解。反射提供了封装程序集,模块 和类型对象,可以用反射动态地创建类型的实例,将类型绑定到现有对象,或者从现有对象类型里获取类 型,然后调用类型的方法或访问字段和属性。 序列化:将对象转换为另一种媒介传输的格式过程。如,序列化一个对象,用Http通过internet在客 户端和服务器之间传递该对象,在另一端用反序列化从该流中重新得到对象。 19,Const和ReadOnly? 答:Const用来申明编程时申明常量,ReadOnly用来申明运行时常量。 20,UDP和TCP连接有和异同? 答:TCP是传输控制协议,提供的是面向连接的,是可靠的,字节流服务,当用户和服务器彼此进行数 据交互的时候,必须在他们数据交互前要进行TCP连接之后才能传输数据。TCP提供超时重拨,检验数据功 能。UDP是用户数据报协议,是一个简单的面向数据报的传输协议,是不可靠的连接。 21,进程和线程分别该怎么理解? 答:进程是比线程大的程序运行单元,都是由操作系统所体会的系统运行单元,一个程序中至少要有 一个进程,有一个进程中,至少要有一个线程,线程的划分尺度要比进程要小,进程拥有独立的内存单元 ,线程是共享内存,从而极大的提高了程序的运行效率同一个进程中的多个线程可以并发执行。 22,ASP。NET页面之间传递值的几种方式? 答:QueryString,session,cookies,application,server.Transfer,respose.redictor. 23. 什么叫应用程序域?什么是托管代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS 、CLS和CLR分别作何解释? 答:应用程序域:就是为安全性,可靠性,隔离性,和版本控制,及卸载程序提供的隔离边界。它通 常由运行库宿主创建,应用程序域提供了一个更安全,用途更广的处理单元。 托管代码:使用CLR编译语言编辑器开发编写的代码就叫托管代码。 装箱和拆箱:是把值类型转换为引用类型的过程,是隐式的,相反的过程就是拆箱,是显式的。 CTS是公共类型系统,CLS是公共语言规范,CLR公共语言运行库。 强类型系统:每个变量和对象都必须具有申明类型。 24.值类型和引用类型的区别? 答:值类型的值是存放在堆栈中的,改变其值,不改变变量原有的值,而引用类型的值是存放在栈中 的,其引用的地址是存放在堆栈中的,改变其值也就改变了变量原有的值。值类型不允许包含null值,然 而可空类型可以将null赋值给值类型l。 25.ASP.net的身份验证方式有哪些? 答:windows,forms,passport 26.解释一下UDDI、WSDL的意义及其作用? 答:UDDI是统一描述集成协议,是一套基于Web的,分布式的,为WEB服务提供的信息注册的实现标准 规范,同时为也是为企业本身提供的Web服务注册以让别的企业能够发现并访问的协议标准。提供了基于标 准的规范,用于描述和发现服务,还提供了一组基于因特网的实现。 WSDL这是一个基于XML的描述WEB服务的接口。 27.什么是SOAP? 答:是简单访问协议。是在分布式环境中,交换信息并实现远程调用的协议。是一个基于XML的协议。 使用SOAP,可以不考虑任何传输协议,但通常还是HTTP协议,可以允许任何类型的对象或代码,在任何平 台上,以任一种语言相互通信。它是一种轻量级协议。 28.如何部署一个ASP.net页面? 答:vs2003,vs2005里边都有发表机制,vs2003可以发布然后在复制部署。 Vs2005可以直接部署到对应的位置。 29.如何理解.net中的垃圾回收机制? 答:.NET中的垃圾回收机制是引用程序对内存的回收和释放。当每次用new关键字创建一个对象时,运 行库都要从托管堆中为其分配内存,因为空间是有限的,最终垃圾回收机制是要回收不用的内存的。已释 放内存,重新使用。 30.面向对象的三大基本原则? 答:封装,继承,多态。 31.在.NET中所有类的基类是? 答:object。 32.能用foreach遍历访问的对象需要实现? 答:需要实现IEnumerable接口和GetEnumerator ()方法。 33.Heap与stack的差别? 答:Heap是堆,空间是由手动操作分配和释放的,它的存储区很大的自由存储区。 Stack是栈,是由是操作系统自动分配和释放的,栈上的空间是有限的。程序在编译期间变量和函数分 配内存都是在栈上进行的,且在运行时函数调用时的参数的传递也是在栈上进行的。
希望采纳
『捌』 net开发工程师面试时会问什么问题
其实,不管来是什么样的面试形自,问的问题都差不多,万变不离其宗,都有规律可寻。其实对所有的面试官而言,只有一个目的:在最短的时间里了解到你最多的信息。想高效率的准备面试,先从这七个大方面着手吧!
一、基本情况
1、请用最简洁的语言描述您从前的工作经历和工作成果。
二、专业背景
您认为此工作岗位应当具备哪些素质?
三、工作模式
您平时习惯于单独工作还是团队工作?
四、价值取向
您对原来的单位和上司的看法如何?
五、资质特性
您如何描述自己的个性?
六、薪资待遇
是否方便告诉我您目前的待遇是多少?
七、背景调查
您是否介意我们通过您原来的单位迚行一些调查?
95%的面试基本上都离不开这些问题,当然还有可能问一些专业问题,我想如果你做过的话应该都不是什么难事,一般面试官都不会过多的问专业方面的问题的。