zoukankan      html  css  js  c++  java
  • .Net 面试题 汇总(一)

    1、@page指令只能在_aspx___文件(填写扩展名)中使用,而@Control指令只能用在_ascx___文件(填写扩展名)中使用.

    2、说明控件DataGrid,DataTable,DataView,DetailsView,formView,Repeator常用属性,如果要想把一条记录分成两列显示,以上控件哪些可以用,哪些不可以用?如果可用,如何处理?
    答:DataMember:绑定的表或者视图,DataSourseID:数据源控制的ID,Visible:是否显示该控件. FormView,Repeator可以用,其他的控件不能可用,在ItemTemplate模板里用表格或者用列表来显示.

    3、写出下列的含义 <% %>,<%# %>
    答:<% %>是服务器端代码块
    <%# %>表示绑定的数据源

    4、请解释Page.IsPostBack,Response.Write,Response.End,DBNull.Value, DataSet,DataTable,DataView,SqlDataReader,stringbuilder,ArrayList?
    Page.IsPostBack:是否正是被首次加载
    Response.Write:打印指定的文本
    Response.End:停止当前的程序并返回结果
    DBNull是一个类。DBNull.Value是它唯一的实例。它指数据库中数据为空(<NULL>)时,在.net中的值。
    DataSet:DataSet是数据在内存中的表示形式,是不依赖与数据库的独立数据集合.
    DataTable:是一个包含列和行表.
    DataView:数据视图
    SqlDataReader:提供一种从 SQL Server 数据库读取行的只进流的方式。


    5、 stringbuilder:StringBuffer线程安全的可变字符序列。一个类似于 String 的字符串缓冲区,但不能修改。虽然在任意时间点上它都包含某种特定的字符序列,但通过某些方法调用可以改变该序列的长度和内容。
    ArrayList:动态加载的数组
    partial,protected,private,public的含义:
    答:partial:仅所属类的成员才可以访问
    protected:可被所属的类或派生自所属类的类型访问
    public:访问不受限制。

    6、如何理解死锁的概念?死锁是如何形成的?在应用中应注意什么事项避免死锁?
    死锁是一种条件,不仅仅是在关系数据库管理系统 (RDBMS) 中发生,在任何多用户系统中都可以发生的。当两个用户(或会话)具有不同对象的锁,并且每个用户需要另一个对象的锁时,就会出现死锁。每个用户都等待另一个用户释放他的锁。当两个连接陷入死锁时,Microsoft? SQL Server? 会进行检测。其中一个连接被选作死锁牺牲品。该连接的事务回滚,同时应用程序收到错误。
    阻塞
      任何基于锁的并发系统都不可避免地具有可能在某些情况下发生阻塞的特征。当一个连接控制了一个锁,而另一个连接需要冲突的锁类型时,将发生阻塞。其结果是强制第二个连接等待,或在第一个连接上阻塞。
    其实所有的死锁最深层的原因就是一个——资源竞争。
    表现一:
    一个用户A 访问表A(锁住了表A),然后又访问表B,另一个用户B 访问表B(锁住了表B),然后企图访问表A。这时用户A由于用户B已经锁住表B,它必须等待用户B释放表B,才能继续,好了他老人家就只好老老实实在这等了。
    同样用户B要等用户A释放表A才能继续这就死锁了。
    解决方法:
    这种死锁是由于你的程序的BUG产生的,除了调整你的程序的逻辑别无他法。
    仔细分析你程序的逻辑:
    1:尽量避免同时锁定两个资源;
    2: 必须同时锁定两个资源时,要保证在任何时刻都应该按照相同的顺序来锁定资源。
    表现二:
    用户A读一条纪录,然后修改该条纪录,这是用户B修改该条纪录,这里用户A的事务里锁的性质由共享锁企图上升到独占锁(for update),而用户B里的独占锁由于A有共享锁存在所以必须等A释放掉共享锁,而A由于B的独占锁而无法上升的独占锁也就不可能释放共享锁,于是出现了死锁。
    这种死锁比较隐蔽,但其实在稍大点的项目中经常发生。
    解决方法:
    让用户A的事务(即先读后写类型的操作),在select 时就是用Update lock

    7、什么是事务? 使用事务的语句有哪些?
    答:事务是一种机制,是一个操作序列,它包括了一组数据库操作命令,并且所有的命令作为一个整体向
    系统提交或者撤消操作请求,要么全部,要么全部不执行.
    begin transaction
    commit transaction
    rollback transaction

    8、在update触发器中如何使用修改前,后的数据?
    if update(字段1)
    begin
    ...
    end


    9、有一职员表,字段有工卡和姓名,写出所有姓名重复的职员信息的SQL
    语句。
    答:select * from test where name in(
    select name from test group by name having count(name)>1)

    10、有两张表Table1,Table2 ,都只有一个字段。Table有数据'1','2','3','4',Table2有'1','3'.写出一句通用Sql语句将表Table1的记录同步到Table2中!。
    答: insert table2 (字段) select '2' union select '4';

    11、请谈谈你对OOP的理解。
    面向对象编程(Object Oriented Programming,OOP,面向对象程序设计)是一种计算机编程架构。OOP 的一条基本原则是计算机程序是由单个能够起到子程序作用的单元或对象组合而成。OOP 达到了软件工程的三个主要目标:重用性、灵活性和扩展性。为了实现整体运算,每个对象都能够接收信息、处理数据和向其它对象发送信息。OOP 主要有以下的概念和组件:
      组件 -数据和功能一起在运行着的计算机程序中形成的单元,组件在 OOP 计算机程序中是模块和结构化的基础。
      抽象性 -程序有能力忽略正在处理中信息的某些方面,即对信息主要方面关注的能力。
      封装 -也叫做信息封装:确保组件不会以不可预期的方式改变其它组件的内部状态;只有在那些提供了内部状态改变方法的组件中,才可以访问其内部状态。每类组件都提供了一个与其它组件联系的接口,并规定了其它组件进行调用的方法。
      多态性 -组件的引用和类集会涉及到其它许多不同类型的组件,而且引用组件所产生的结果得依据实际调用的类型。
    继承性 - 允许在现存的组件基础上创建子类组件,这统一并增强了多态性和封装性。典型地来说就是用类来对组件进行分组,而且还可以定义新类为现存的类的扩展,这样就可以将类组织成树形或网状结构,这体现了动作的通用性。

    12、 简述 private、 protected、 public、 internal 修饰符的访问权限。
    private : 私有成员, 在类的内部才可以访问。protected : 保护成员,该类内部和继承类中可以访问。public : 公共成员,完全公开,没有访问限制。internal: 在同一命名空间内可以访问。

    13、 写出一条Sql语句: 取出表A中第31到第40记录(SQLServer, 以自动增长的ID作为主键, 注意:ID可能不是连续的。)
    select row,name from(select row_number() over(order by id) as row,name from A) as AWithRowNumber where row >=31 and row<=40

    14、列举ASP.NET 页面之间传递值的几种方式。
    1. 使用QueryString, 如....?id=1; response. Redirect(),这种方法的主要优点是实现起来非常简单,然而它的缺点是传递的值是会显示在浏览器的地址栏上的(不安全),同时又不能传递对象
    2.使用Session变量,缺点是在Session变量存储过多的数据会消耗比较多的服务器资源,最好的解决办法是用完session,用remove删除
    3.使用Server.Transfer,将要传递的数据使用get方法封装,在另一个页面以对象属性的方式来存取显露的值,在目标页面实例源页面,WebForm1 wf1;wf1=(WebForm1)Context.Handler;Label1.Text=wf1.Name;Label2.Text=wf1.EMail;
    2。请说明在.net中常用的几种页面间传递参数的方法,并说出他们的优缺点。
    session(viewstate) 简单,但易丢失
    application 全局
    cookie 简单,但可能不支持,可能被伪造
    input ttype="hidden" 简单,可能被伪造
    url参数简单,显示于地址栏,长度有限
    数据库稳定,安全,但性能相对弱

    15、override与重载的区别
    Override用来重写父类的方法,重载使用相同名的方法或操作符拥有不同类型的参数,重写是子类的方法覆盖父类的方法,要求方法名和参数都相同 ,重载是在同一个类中的两个或两个以上的方法,拥有相同的方法名,但是参数却不相同,方法体也不相同,最常见的重载的例子就是类的构造函数

    16、.net的错误处理机制是什么
    .net错误处理机制采用try->catch->finally结构,发生错误时,层层上抛,直到找到匹配的Catch为止。

    17、C#中接口和类的异同
    接口和类都是类,不同的是,接口只包含方法或属性的声明,不包含具体实现方法的代码,接口可以实现多继承,而类只能是单继承,继承接口的类必须实现接口中声明的方法或属性。接口主要定义一种规范,统一调用方法,在大型项目中接口正发挥日益重要的作用。

    18、DataReader和DataSet的异同
    DataReader和DataSet最大的区别在于,DataReader使用时始终占用SqlConnection,在线操作数据库..任何对SqlConnection的操作都会引发DataReader的异常..因为DataReader每次只在内存中加载一条数据,所以占用的内存是很小的..因为DataReader的特殊性和高性能.所以DataReader是只进的..你读了第一条后就不能再去读取第一条了..
    DataSet则是将数据一次性加载在内存中.抛弃数据库连接..读取完毕即放弃数据库连接..因为DataSet将数据全部加载在内存中.所以比较消耗内存...但是确比DataReader要灵活..可以动态的添加行,列,数据.对数据库进行回传更新操作...

    19、 在c#中using和new这两个关键字有什么意义,请写出你所知道的意义?
    Using 引入一个名子空间,或在使用了一个对像后自动调用其IDespose,New 实例化一个对像,或修饰一个方法,表此方法完全重写此方法

    20、谈谈类和结构的区别?

    最大区别一个是引用类型,一个是值类型 默认成员访问为public是另外一个区别

    21、 在.net(C# or vb.net)中如何获得当前窗体或控件的句柄,特别是控件本身的句柄(请列举)。
    this(C#) Me(vb.net).

    22、在.net(C# or vb.net)中如何用户自定义消息,并在窗体中处理这些消息。
    在form中重载DefWndProc函数来处理消息:
    protected override void DefWndProc ( ref System.WinForms.Message m )
    {
    switch(m.msg)
    {
    case WM_Lbutton :
     ///string与MFC中的CString的Format函数的使用方法有所不同
     string message = string.Format("收到消息!参数为:{0},{1}",m.wParam,m.lParam);
     MessageBox.Show(message);///显示一个消息框
     break;
    case USER:
    处理的代码
    default:
     base.DefWndProc(ref m);///调用基类函数处理非自定义消息。
     break;
    }
    }

    23、 在.net(C# or vb.net)如何启动另一个程序。process

    24、 在.net(C# or vb.net)中如何取消一个窗体的关闭
    private void Form1_Closing(object sender, System.ComponentModel.CancelEventArgs e)
    {
    e.Cancel=true;
    }

    25、 在.net(C# or vb.net)中,Appplication.Exit 还是 Form.Close有什么不同?
    答案:一个是退出整个应用程序,一个是关闭其中一个form

    27、在C#中有一个double型的变量,比如10321.5,比如122235401.21644,作为货币的值如何按各个不同国家的习惯来输出。比如美国用$10,321.50和$122,235,401.22而在英国则为£10 321.50和£122 235 401.22
    答案:
    System.Globalization.CultureInfo MyCulture = new System.Globalization.CultureInfo("en-US");
    //System.Globalization.CultureInfo MyCulture = new System.Globalization.CultureInfo("en-GB");为英国货币类型
    decimal y = 9999999999999999999999999999m;
    string str = String.Format(MyCulture,"My amount = {0:c}",y);

    28、 62-63=1 等式不成立,请移动一个数字(不可以移动减号和等于号),使得等式成立,如何移动?
    答案:62移动成2的6次方

    29、new有几种用法
    第一种:new Class();
    第二种:覆盖方法
    public new XXXX(){}
    第三种:new 约束指定泛型类声明中的任何类型参数都必须有公共的无参数构造函数。

    30、如何把一个array复制到arrayList里
    foreach( object o in array )arrayList.Add(o);

    31、datagrid.datasouse可以连接什么数据源 [dataset,datatable,dataview]
    dataset,datatable,dataview , IList

    32、概述反射和序列化
    反射:程序集包含模块,而模块包含类型,类型又包含成员。反射则提供了封装程序集、模块和类型的对象。您可以使用反射动态地创建类型的实例,将类型绑定到现有对象,或从现有对象中获取类型。然后,可以调用类型的方法或访问其字段和属性
    序列化:序列化是将对象转换为容易传输的格式的过程。例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象。在另一端,反序列化将从该流重新构造对象。

    33、概述o/r mapping 的原理
    利用反射,配置 将类于数据库表映射

    34、用sealed修饰的类有什么特点
    sealed 修饰符用于防止从所修饰的类派生出其它类。如果一个密封类被指定为其它类的基类,则会发生编译时错误。
    密封类不能同时为抽象类。
    sealed 修饰符主要用于防止非有意的派生,但是它还能促使某些运行时优化。具体说来,由于密封类永远不会有任何派生类,所以对密封类的实例的虚拟函数成员的调用可以转换为非虚拟调用来处理。

    35、详述.NET里class和struct的异同!
    class:放在 ? struct放在?
    struct值传递
    类与结构有很多相似之处:结构可以实现接口,并且可以具有与类相同的成员类型。然而,结构在几个重要方面不同于类:结构为值类型而不是引用类型,并且结构不支持继承。结构的值存储在“在堆栈上”或“内联”。细心的程序员有时可以通过聪明地使用结构来增强性能。

    36、概述.NET里对 remoting 和 webservice 两项技术的理解和实际中的应用。
    远程逻辑调用,remoing接口只能用在.net中

    37、什么是code-behind技术 aspx and cs

    38、概述三层结构体系 web/business/dataaccess

    39、asp.net如何实现MVC模式,举例说明! web/business/dataaccess

    40、什么是ASP.net中的用户控件
    答:用户控件就是.ascx扩展名的东西喽,可以拖到不同的页面中调用,以节省代码.比如登陆可能在多个页面上有,就可以做成用户控件,但是有一个问题就是用户控件拖到不同级别的目录下后里面的图片等的相对路径会变得不准确,需要自已写方法调整.

    41、什么叫应用程序域?什么是受管制的代码?什么是强类型系统?什么是装箱和拆箱?什么是重载?CTS、CLS和CLR分别作何解释?
    答:装箱就是把值类型转成引用类型,从MS IL角度看好像是boxing,没记错的话是把值从堆栈转到堆中.拆箱相反,重载就是指一个方法名同,参数个数不同,返回值可以相同的方法. CLR(公用语言运行时) CLS(共语言规范) CTS(通用类型系统)

    42、列举一下你所了解的XML技术及其应用
    答:XML可是好东西,保存配置,站与站之间的交流,WEB SERVICE都要用它.

    43、值类型和引用类型的区别?写出C#的样例代码。
    答:结构是值类型,类是引用类型,所以传结构就是值类型的应用啦,传对象或类就是引用类型的,这个不用多写了吧.

    44、ADO.net中常用的对象有哪些?分别描述一下。
    答:connection command sqladapter dataset datatable dataview等等.写不完了.

    45、如何理解委托?
    答:据说相当于函数指针,定义了委托就可以在不调用原方法名称的情况下调用那个方法.
    msdn2005中是这样解释的:
    委托具有以下特点:
    委托类似于 C++ 函数指针,但它是类型安全的。
    委托允许将方法作为参数进行传递。
    委托可用于定义回调方法。
    委托可以链接在一起;例如,可以对一个事件调用多个方法。
    方法不需要与委托签名精确匹配。有关更多信息,请参见协变和逆变。
    C# 2.0 版引入了匿名方法的概念,此类方法允许将代码块作为参数传递,以代替单独定义的方法。

    46、C#中的接口和类有什么异同。
    答:接口是负责功能的定义,项目中通过接口来规范类,操作类以及抽象类的概念!
    而类是负责功能的具体实现!
    在类中也有抽象类的定义,抽象类与接口的区别在于:
    抽象类是一个不完全的类,类里面有抽象的方法,属性,也可以有具体的方法和属性,需要进一步的专业化。
    但接口是一个行为的规范,里面的所有东西都是抽象的!
    一个类只可以继承一个基类也就是父类,但可以实现多个接口

    47、.net中读写数据库需要用到哪些类?他们的作用
    答:这个类自已可以写的啊,你是指基类吗?那configuration,sqlconnection,sqlcommand等都要用到.

    48、UDP连接和TCP连接的异同。
    答:前者只管传,不管数据到不到,无须建立连接.后者保证传输的数据准确,须要连结.

    49、ASP.net的身份验证方式有哪些?分别是什么原理?
    答:form认证,windows集成认证等,原理不清楚.

    50、什么是code-Behind技术。
    答:代码分离,这是个明智的东西,像ASP这样混成一堆很不爽.或者可以理解成HTML代码写在前台,C#代码写在后台.当然前台也有脚本,类的调用等,其实写在一起也是可以的.

    作者:陌轩君 
    出处:http://www.cnblogs.com/yuan-jun/p/6496543.html
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    数据结构与算法20170804
    设计模式之抽象工厂模式20170803
    设计模式之建造者模式20170802
    设计模式之工厂方法模式20170801
    设计模式之中介者模式20170731
    设计模式之门面模式20170728
    设计模式之适配器模式20170727
    设计模式之装饰模式20170726
    AndroidStudio 开发JNI
    NDK开发: 打印C代码的调试信息Log
  • 原文地址:https://www.cnblogs.com/yuan-jun/p/6496543.html
Copyright © 2011-2022 走看看