1、在c#中,string str = null 与 string str = “” 请尽量使用文字或图象说明其中的区别。
回答要点:说明详细的空间分配。(10分)
答:string str = null 是不给他分配内存空间,而string str = "" 给它分配长度为空字符串的内存空间.
2、请详述在dotnet中类(class)与结构(struct)的异同:(10分)
答: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 table1
where 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)
答:ws主要是可利用http,穿透防火墙。而remoting可以利用tcp/ip,二进制传送提高效率。
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 );
}
}
简单的说就是从根节点开始遍历找子节点,在从找到的子节点找它的子节点,一层层下去
新闻热点
疑难解答