1、在C#中,string str = null 与 string str = “” 请尽量使用文字或图象说明其中的区别。
回答要点:说明详细的空间分配。(10分)解:string str=null 是不给分配内存空间;而string str=””给分配长度为空的字符串的内存空间。string str=null没有string对象,string str=“”有一个字符串对象
2、请详述在dotnet中类(class)与结构(struct)的异同:(10分)
解:1.class可以被实例化,属于引用类型,是分配在内存的堆上的;
struct属于值类型,是分配在内存的栈上的。
2.class可以实现单继承,实现接口;struct只能实现接口
3.class实例由垃圾回收机制来保证内存的回收处理;
struct变量使用完后立即自动解除内存分配
3、根据委托(delegate)的知识,请完成以下用户控件中代码片段的填写:(10)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 );
4、分析以下代码,完成填空(10分)string strTmp = "abcdefg某某某";int i= System.Text.Encoding.Default.GetBytes(strTmp).Length;int j= strTmp.Length;以上代码执行完后,i= j=解:i=13,j=10
5、SQLSERVER服务器中,给定表 table1 中有两个字段 ID、LastUpdateDate,ID表示更新的事务号, LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号。(10)解:select ID
from table1where LastUpdateDate = (select MAX(LastUpdateDate) from table1)6、根据线程安全的相关知识,分析以下代码,当调用test方法时i>10时是否会引起死锁?并简要说明理由。(10分)
public void test(int i){ lock(this){ if (i>10){ i--;test(i);}}}解:不会发生死锁,(但有一点int是按值传递的,所以每次改变的都只是一个副本,因此不会出现死锁。但如果把int换做一个object,那么死锁会发生)7、分析以下代码。(10)public static void test(string ConnectString){ System.Data.OleDb.OleDbConnection conn = new System.Data.OleDb.OleDbConnection();conn.ConnectionString = ConnectString;try{ conn.Open();…….}catch(Exception Ex){ MessageBox.Show(Ex.ToString());}finally{ if (!conn.State.Equals(ConnectionState.Closed))conn.Close();}
请问
1)以上代码可以正确使用连接池吗?解:如果传入的connectionString是一模一样的话,可以正确使用连接池。不过一模一样的意思是,连字符的空格数,顺序完全一致。2)以上代码所使用的异常处理方法,是否所有在test方法内的异常都可以被捕捉并显示出来?解:只可以捕捉数据库连接中的异常吧. (finally中,catch中,如果有别的可能引发异常的操作,也应该用try,catch。所以理论上并非所有异常都会被捕捉。)8、简要谈一下您对微软.NET 构架下remoting和webservice两项技术的理解以及实际中的应用。(10)
解:1.WebService主要是利用HTTP,穿透防火墙;而Remoting可以利用TCP/IP,二进制传送提高效率。
2.WebService是通过XML传输数据,是基于XML的,所以它是跨平台的,通过HTTP协议通信;而Remoting是基于.NET平台的,传输二进制数据,所以速度快,可以走多种协议。
3.WebService通过网络提供服务,信息传送是XML数据包,是用SOAP封装的,是通过HTTP传输的;Remoting通过服务器端向客户端发送一个进程编号,一个程序域编号,以确定对象的位置,它是一个远程调用,可以利用HTTP,TCP等多种协议传输数据。
WebService能使得运行在不同机器上的不同应用无须借助附加的,专门的第三方软件或硬件,就可以相互交换数据或集成。
Remoting能让我们进行分布式开发,速度快,可以做到保持对象的状态。
9、公司要求开发一个继承System.Windows.Forms.ListView类的组件,要求达到以下的特殊功能:点击ListView各列列头时,能按照点击列的每行值进行重排视图中的所有行 (排序的方式如DataGrid相似)。根据您的知识,请简要谈一下您的思路:(10)解:根据点击的列头,包该列的ID取出,按照该ID排序后,在给绑定到ListView中
10、给定以下XML文件,完成算法流程图。(10)<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 ); }}