.Net知识大全(个人整理)
.net知识大全
本章内容适用于对.net有一定基础的或者是想通过本文章对.net基础知识记不清楚的朋友,可以通过本文章进行回顾。
面试的时候可能也会遇到相应的题目,建议面试前进行回顾!!!
1.net和c#是什么关系?
c#就是为宣传.net而创立的,它直接集成于visual studio .net中,vb也在.net 1.0发布后对其进行支持, 所以这两门语言与.net平台耦合度很高,并且.net上的技术大多都是以c#编程语言为示例,所以经常就.net和c#混为一谈(实质上它们是相辅相成的两个概念)。
而作为一个开发者平台,它不仅仅是包含开发环境、技术框架、社区论坛、服务支持等,它还强调了平台的跨语言、跨平台编程的两个特性
2 .列举asp.net 页面之间传递值的几种方式。
答:
- querystring是一种非常简单的传值方式,他可以将传送的值显示在浏览器的地址栏中。如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法。但是对于传递数组或对象的话,就不能用这个方法了。
- application对象的作用范围是整个全局,也就是说对所有用户都有效。其常用的方法用lock和unlock。
- session变量 想必这个肯定是大家使用中最常见的用法了,作用于用户个人,所以,过量的存储会导致服务器内存资源的耗尽。
- cookie对象变量这个也是大家常使用的方法,与session一样,其是什对每一个用户而言的,但是有个本质的区别,即cookie是存放在客户端的,而session是存放在服务器端的。而且cookie的使用要配合asp.net内置对象request来使用。
- server.transfer方法这个才可以说是面象对象开发所使用的方法,其使用server.transfer方法把流程从当前页面引导到另一个页面中,新的页面使用前一个页面的应答流,所以这个方法是完全面象对象的,简洁有效。
3. 一列数的规则如下: 1、1、2、3、5、8、13、21、34...... 求第30位数是多少, 用递归算法实现。
答:public static int calculate(int x)
{
int retint = 1;
if (x > 2)
{
return calculate(x - 2) + calculate(x - 1);
}
else
return retint;
}
4.c#中的委托是什么?事件是不是一种委托?
答 : 委托是一种定义方法签名的类型,可以与具有兼容签名的任何方法关联。可以通过委
托调用方法。委托用于将方法作为参数传递给其他方法。
委托具有以下特点:
- 委托类似于 c++ 函数指针,但它们是类型安全的。
- 委托允许将方法作为参数进行传递。
- 委托可用于定义回调方法。
- 委托可以链接在一起;例如,可以对一个事件调用多个方法。
- 方法不必与委托签名完全匹配。
事件是一种特殊的委托。
5.override与重载的区别
答 :
override:要扩展或修改继承的方法、属性、索引器或事件的抽象实现或虚实现,重写的基方法必须与 override 方法具有相同的签名。
方法重载:一个类中可以有一个以上的方法拥有相同的名称。但必须有不相同的签名。
6.如果在一个b/s结构的系统中需要传递变量值,但是又不能使用session、cookie、application,您有几种方法进行处理?
答 : querystring、 server.transfer方法。
7.请编程遍历页面上所有textbox控件并给它赋值为string.empty?
答:
foreach (control control in this.controls)
{
if (control is textbox)
{
textbox tb = (textbox)control;
tb.text = string.empty;
}
}
8.请编程实现一个冒泡排序算法?
答:
//冒泡排序
public static void maopaosort(ref int[] arrays)
{
if (arrays != null && arrays.length > 0)
{
for (int i = 1; i < arrays.length; i++)
{
bool ischange = false;
for (int j = 0; j < arrays.length - i; j++)
{
if (arrays[j] > arrays[j + 1])
{
int tempvalue = arrays[j];
arrays[j] = arrays[j + 1];
arrays[j + 1] = tempvalue;
ischange = true;
}
}
if (!ischange)
break;
}
}
}
9.描述一下c#中索引器的实现过程,是否只能根据数字进行索引?
答:索引器允许类或结构的实例就像数组一样进行索引。索引器类似于属性,不同之处在于它们的访问器采用参数。 public returntype this[ paramtype index]{get{} set{}},可以用任何类型进行索引。
10.求以下表达式的值,写出您想到的一种或几种实现方法: 1-2+3-4+……+m
答: public static int summethod1(int m)
{
int sum=0;
for (int i = 1; i <= m; i++)
{
if (i % 2 != 0)
sum += i;
else
sum -= i;
}
return sum;
}
public static int summethod2(int m)
{
int sum = 0;
if (m % 2 != 0)
sum = m / 2 + 1;
else
sum = -(m / 2);
return sum;
}
12.在下面的例子里
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
13.什么叫应用程序域?
答:应用程序域 (application domain) (appdomain) 一种边界,它由公共语言运行库围绕同一应用程序范围内创建的对象建立(即,从应用程序入口点开始,沿着对象激活的序列的任何位置)。应用程序域有助于将在一个应用程序中创建的对象与在其他应用程序中创建的对象隔离,以使运行时行为可以预知。在一个单独的进程中可以存在多个应用程序域
14.cts、cls、clr分别作何解释?
答:cts:通用类型系统。cls:通用语言规范。clr:公共语言运行库。
15.什么是装箱和拆箱?
答:装箱:装箱转换是指将一个值类型隐式或显式地转换成一个object类型,拆箱:拆箱转换是指将一个对象类型显式地转换成一个值类型。
16.什么是受管制的代码?
答:受托管的代码不能直接写内存,是安全的,它受clr的内存安全管理,而非托管代码是非安全代码,可以使用指针操作内存
18.net中读写数据库需要用到那些类?他们的作用?
答:dataset:数据存储器
command对象,用来执行各种sql语句或者调用存储过程。
adapter对象,数据适配器,用来执行sql语句,配合数据集执行比较多。
datareader,只读的对象,有着很高的性能。
21.在.net中,配件的意思是?
答:程序集。(中间语言,源数据,资源,装配清单)
22.常用的调用webservice的方法有哪些?
答: 1.使用wsdl.exe命令行工具。
2.使用vs.net中的add web reference菜单选项
23..net remoting 的工作原理是什么?
答:服务器端向客户端发送一个进程编号,一个程序域编号,以确定对象的位置。
31.公司要求开发一个继承system.windows.forms.listview类的组件,要求达到以下的特殊功能:点击listview 各列列头时,能按照点击列的每行值进行重排视图中的所有行 (排序的方式如datagrid相似)。根据您的知识,请简要谈一下您的思路
答:根据点击的列头,包该列的名称取出,按照该列名排序后,再绑定到listview中。
35.能用foreach遍历访问的对象需要实现ienumerable接口或声明getenumerator方法的类型。
36.gc是什么? 为什么要有gc?
答:gc是垃圾收集器。程序员不用担心内存管理,因为垃圾收集器会自动进行管理。要请求垃圾收集,可以调用下面的方法之一: system.gc.collect();
37.string s = new string("xyz");创建了几个string object?
答:两个对象,一个是“xyx”,一个是指向“xyx”的引用对像s。
38.abstract class和interface有什么区别?
答:
抽象类:
- 只能用做其它类的基类,它就是被设计来被继承的。
- 不能创建它的实例。
- 它使用abstract修饰符来声明。
- 抽象类可以包含抽象成员,但不是必须的,它的成员可以抽象成员和普通带实现的成员的任意组合。
- 它自己可以派生自另一个抽象类。任何派生自抽象类的类必须使用override关键字实现该类所有的抽象成员,除非派生类自己也是抽象类。
接口:
- 接口是表示一组函数成员而不实现成员的引用类型。其它类和结构可以实现接口。
- 接口声明不包括数据成员。
- 接口声明只能包含如下类型的静态成员函数的声明:方法、属性、事件、索引。
- 接口的成员不能包含任何实现代码,而在每一个成员声明的主体后必须使用分号。
- 接口名称必须从大写的i开始。它和类一样,也可以声明成分部接口。
- 接口声明可以有任何的访问类型:public、protected、internal、private。
- 接口成员是隐式public的,不允许有任何访问修饰符。
1, 什么是线程池
为了帮我们降低创建和销毁线程相关的成本,clr为每一个进程维护了一个线程池。一开始进程的线程池是空的,如果进程使用的线程被创建,并且完成了线程的执行,它不会被销毁,而是加入到进程的线程池中,这后,如果进程需要一个另外一个线程,clr就会从池中还原一个线程,这就节省了很多时间。
39.启动一个线程是用run()还是start()?
答:启动一个线程是调用start()方法,这并不意味着线程就会立即运行,只是进入了可运行状态。直接调用run()方法不会产生线程,而是把它当作普通的方法调用,马上执行
40.接口是否可继承接口? 抽像类是否可实现(implements)接口? 抽像类是否可继承实体类(concrete class)?
答:接口可以继承接口。抽像类可以实现(implements)接口,抽像类是否可继承实体类,但前提是实体类必须有明确的构造函数。
41.构造器constructor是否可被override?
答:构造器constructor不能被继承,因此不能重写overriding,但可以被重载overloading。
42.是否可以继承string类?
答:不可以,因为string类是密封类,被sealed修饰符所修饰。
44.两个对像值相同(x.equals(y) == true),但却可有不同的hash code,这句话对不对?
答:不对,有相同的hash code。
hash code:可以简单的理解为内存的地址。
"==" : 操作比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量在堆中存储
的地址是否相同,即栈中的内容是否相同。
"equals" : 操作表示的两个变量是否是对同一个对象的引用,即堆中的内容是否相同。
而字符串是一个特殊的引用型类型,在c#语言中,重载了string 对象的很多方法方法(包括equals()方法),使string对象用起来就像是值类型一样。
45.swtich是否能作用在byte上,是否能作用在long上,是否能作用在string上?
答:可以。
47.当一个线程进入一个对象的一个synchronized方法后,其它线程是否可进入此对象的其它方法?
不能,一个对象的一个synchronized方法只能由一个线程访问。
49.list, set, map是否继承自collection接口?
答:list,set是map不是
51.数组有没有length()这个方法? string有没有length()这个方法?
答:数组和string都没有length()方法,只有length属性。
52.sleep() 和 wait() 有什么区别?
答:sleep()方法是将当前线程挂起指定的时间。
wait()释放对象上的锁并阻塞当前线程,直到它重新获取该锁。
53.short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
答:short s1 = 1; s1 = s1 + 1;有错,s1是short型,s1+1是int型,不能隐式转化为short型。可修改为s1 =(short)(s1 + 1) 。short s1 = 1; s1 += 1正确。
复合赋值表达式自动地将所执行计算的结果转型为其左侧变量的类型,s1+=1等价于s1=(short)s1+1;
55.如何处理几十万条并发数据?
答:用存储过程或事务。取得最大标识的时候同时更新..注意主键不是自增量方式这种方法并发的时候是不会有重复主键的..取得最大标识要有一个存储过程来获取.
56.session有什么重大bug,微软提出了什么方法加以解决?
答:是iis中由于有进程回收机制,系统繁忙的话session会丢失,可以用sate server或sql server数据库的方式存储session不过这种方式比较慢,而且无法捕获session的end事件。
57.进程和线程的区别?
答:进程是系统进行资源分配和调度的单位;线程是cpu调度和分派的单位,一个进程可以有多个线程,这些线程共享这个进程的资源。
进程:进程就是一组资源,它们构成了一个正在运行的程序。
线程:在进程中系统创建了一个叫做线程的内核对象,线程体现了一个程序的真实执行情况。
58.堆和栈的区别?
答:栈是编译期间就分配好的内存空间,因此你的代码中必须就栈的大小有明确的定义;堆是程序运行期间动态分配的内存空间,你可以根据程序的运行情况确定要分配的堆内存的大小。
栈:它是一个内存数组,是一个lifo的数据结构,数据只能从栈顶插入和删除。
堆:它是一块内存区域,在堆里可以分配大块的内存用于存储某类型的数据,堆里的内存可以以任意顺序存入和取出。
59.成员变量和成员函数前加static的作用?
答:
- 它们用来反映类的状态。
- 静态成员它被类的所有实例所共享,所有实例都访问同一内存位置。
- 它们独立于所有的类实例,即使没有类实例,也可以调用类的静态成员。
60.asp.net与asp相比,主要有哪些进步?
答:asp解释形,aspx编译型,性能提高,可以跟美工的工作分开进行,更有利于团队开发。
61.产生一个int数组,长度为100,并向其中随机插入1-100,并且不能重复。
public static int[] buildintarray()
{
int[] retsint = new int[100];
list<int> templist = new list<int>();
random random = new random();
while(templist.count < 100)
{
int num = random.next(1, 101);
if (!templist.contains(num))
templist.add(num);
}
templist.sort();
for (int i = 0; i < templist.count; i++)
retsint[i] = templist[i];
return retsint;
}
62.请说明在.net中常用的几种页面间传递参数的方法,并说出他们的优缺点。
答:
- querystring 传递一个或多个安全性要求不高或是结构简单的数值。但是对于传递数组或对象的话,就不能用这个方法了
- session(viewstate) 简单,但易丢失 作用于用户个人,过量的存储会导致服务器内存资源的耗尽。
- application 对象的作用范围是整个全局,也就是说对所有用户都有效。其常用的方法用lock和unlock
- cookie 简单,但可能不支持,可能被伪造 cookie是存放在客户端的,而session是存放在服务器端的。而且cookie的使用要配合asp.net内置对象request来使用
- input ttype="hidden" 简单,可能被伪造
- url参数简单,显示于地址栏,长度有限
- server.transfer 把流程从当前页面引导到另一个页面中,新的页面使用前一个页面的应答流
- 数据库稳定,安全,但性能相对弱
63.请指出gac的含义?
答:全局程序集缓存。
gac(global assembly cache),他的作用是可以存放一些有很多程序都要用到的公共assembly。这样,很多程序就可以从gac里面取得assembly,而不需要再把所有要用到的assembly都拷贝到应用程序的执行目录下面。
64.向服务器发送请求有几种方式?
答:get,post。get一般为链接方式,post一般为按钮方式。
区别:
get 方式, 服务器端用request.qurystring取变量的值,安全性不高,传送数据量小。
post方式,服务器端用request.form获取提交的数据,安全性高。
建议:
1、get方式的安全性较post方式要差些,包含机密信息的话,建议用post数据提交方式;
2、在做数据查询时,建议用get方式;而在做数据添加、修改或删除时,建议用post方式。
65.datareader与dataset有什么区别?
答:
- 连接数据库时dataset是非面向连接的,而datareader是面向连接的。
- dataset表示一个数据集,是数据在内存中的缓存,可以包括多个表,是保存数据的数据结构。而datareader不承担保存数据的责任,它只负责从数据源读取数据到本地而已,它不是数据结构,而是网络通讯组件的高层封装。
- dataset可以离线处理,前后滚动,而datareader不能离线处理,且是只读向前的,速度快。
- dataset可以存储数据库各种对象的,比如表触发器等,可以更新回原来的数据库。而datareader只能存储游标记录,不可以更新回原来的数据库, 它类似一个只能向前的游标记录集。
66.软件开发过程一般有几个阶段?每个阶段的作用?答:
软件开发一般分为五个阶段:
-
问题的定义及规划
此阶段是软件开发与需求方共同讨论,主要确定软件的开发目标及其可行性。 -
需求分析
在确定软件开发可行性的情况下,对软件需要实现的各个功能进行详细需求分析。需求分析阶段是一个很重要的阶段,这一阶段做的好,将为整个软件项目的开发打下良好的基础。“唯一不变的是变化本身”,同样软件需求也是在软件开发过程中不断变化和深入的,因此,我们必须定制需求变更计划来应付这种变化,以保护整个项目的正常进行。 -
软件设计
此阶段中要根据需求分析的结果,对整个软件系统进行设计,如系统框架设计、数据库设计等。软件设计一般分为概要设计和详细设计,软件设计将为软件程序编写打下良好的基础。 -
程序编码
此阶段是将软件设计的结果转化为计算机可运行的程序代码。在程序编码中必定要制定统一、符合标准的编写规范。以保证程序的可读性、易维护性。提高程序的运行效率。 -
软件测试
在软件设计完成之后要进行严密的测试,一发现软件在整个软件设计过程中存在的问题并加以纠正。整个测试阶段分为单元测试、组装测试、系统测试三个阶段进行。测试方法主要有白盒测试和黑盒测试。 - 6.部署及维护。
67.在c#中using和new这两个关键字有什么意义,请写出你所知道的意义?
uning:
- using做为命名空间指令:通过在源文件顶端放置using命名空间指令以避免不得不使用长名称,它通知编译器你将要使用来自某个指定命名空间的类型。
- using做为别名指令:它允许对一个命名空间或命名空间中的一个类型起一个别名。
- using语句:某些类型的非托管对象有数量限制或很耗费系统资源,这样在代码使用完它们后,就得尽可能快的释放它们,using语句有助于简化该过程并确保这些资源被适当的处置。
new :
- 创建类和结构的实例。
- 隐藏基类的方法。
- 创建匿名类型(var和new关键字一起使用时可以创建匿名类型,匿名类型只是一个继承了object的、没有名称的类,该类的定义从初始化器中推断,类似于隐匿类型化的变量)。
68.需要实现对一个字符串的处理,首先将该字符串首尾的空格去掉,如果字符串中间还有连续空格的话,仅保留一个空格,即允许字符串中间有多个空格,但连续的空格数不可超过一个.
答: string str = " afdkd askdfji ksdafj ";
string strafter = regex.replace(str.trim(), @"\s+", " ");
69.下面这段代码输出什么?为什么?
int i = 5;
int j = 5;
if (object.referenceequals(i, j))
console.writeline("equal");
else
console.writeline("not equal");
答:not equal,因为referenceequals是object的静态方法,用于比较两个引用类型的对象是否是对于同一个对象的引用,对于值类型它总是返回false。
34. referenceequals, == , equals的区别
- string对于声明的相同的字符串在堆上只保留一个copy,所以有相同字符串值的两个字符串变量将会指向相同的reference。
- referenceequals:
它是object的静态方法,用于比较两个引用类型的对象是否是对于同一个对象的引用,对于值类型它总是返回false。 - ==:
它是一个可以重载的二元操作符,可以用于比较两个对象是否相等。
对于内置值类型,==判断的是两个对象的代数值是否相等。它会根据需要自动进行必要的类型转换,并根据两个对象的值是否相等返回true或者false,而对于用户定义的值类型,如果没有重载==操作符,==将是不能够使用的。
对于引用类型,== 默认的行为与referenceequals的行为相同,仅有两个对象指向同一个reference的时候才返回true。但是.net framework中的类很多对==进行了重载,例如string类的==与equals的行为相同,判断两个字符串的内容是否相等。所以在应用中,对于 系统定义的引用类型建议不要使用==操作符,以免程序出现与预期不同的运行结果。 - equals():
它对于值类型和引用类型的定义不同,对于值类型,类型相同,并且数值相同(对于struct的每个成员都必须相同),则equals返回 true,否则返回false。而对于引用类型,默认的行为与referenceequals的行为相同,仅有两个对象指向同一个reference的时 候才返回true。可以根据需要对equals进行重载,例如string类的equals用于判断两个字符串的内容是否相等。
70.什么叫做sql注入,如何防止?请举例说明。
答:利用sql语言漏洞获得合法身份登陆系统。如身份验证的程序设计成:
sqlcommand com=new sqlcommand("select * from users where username='"+t_name.text+"' and pwd='"+t_pwd.text+"'");
object obj=com.excutescale();
if(obj!=null)
{
//通过验证
}
这段代码容易被sql注入。如用户在t_name中随便输入,在t_pwd中输入1' or 1='1 就可以进入系统了。可以采用参数化查询语句进行防止。
71.什么是反射?
答:有关程序及其类型的数据被称为元数据(metadata),它们保存在程序的程序集中。程序在运行时,可以查看其它程序集及其本身的元数据,一个运行的程序查看本身及其它程序集的元数据的行为叫做反射(reflection)。
72.用singleton如何写设计模式
public sealed class sun
{
private static sun instance = null;
private sun(){}
public static sun instance
{
get
{
return instance == null ? instance = new sun() : instance;
}
}
}
73.什么是application pool?
答:web应用,类似thread pool,提高并发性能。
74.什么是虚函数?什么是抽像函数?
- 虚函数:使它们可以在派生类中被重写,它自身可以有函数的实现。
- 抽像函数:规定其非虚子类必须实现的函数,必须被重写,它自身不可有函数的实现
75.什么是xml?
答:xml即可扩展标记语言(extensible markup language)。它是一种以简单文本格式存储数据的方式,这意味着它可以被任何计算机读取,它在.net中执行大量的任务,包括描述应用程序的配置、在web服务之间传输信息等。
77.什么是asp.net中的用户控件?
答:用户控件是能够在其中放置标记和 web 服务器控件的容器。然后,可以将用户控件作为一个单元对待,为其定义属性和方法。有了用户控件,就不必为每个需要相同内容的页面多次创建用户界面,编写代码,而只需要创建一个用户控件,在几个页面中多次使用。
78.列举一下你所了解的xml技术及其应用
答:xml用于配置,用于保存静态数据类型.接触xml最多的是web services..和config,soap协议
79.ado.net中常用的对象有哪些?分别描述一下。
提供者对象:
- connection 提供到数据源的基本连接。
- command 使用它对数据源发出命令。
- commandbuilder 此对象用于构建sql命令,在基于单一表查询的对象中进行数据修改。
- datareader 这是一个快速而易用的对象,可以从数据源中读取仅能前向和只读的数据流。
- dataadapter 它是一个通用的类,可以执行针对数据源的各种操作,包括更新变动的数据,填充dataset对象以及其它操作。
用户对象:
- dataset 它表示一组相关表,在应用程序中这些表作为一个单元来引用。
80.什么是code-behind技术。
答:code-behind技术也称为代码隐藏技术,在asp.net中通过aspx页面指向cs文件的方法实现显示逻辑和处理逻辑的分离,这样有助于web应用程序的创建。比如分工,美工和编程的可以个干各的,不用再像以前asp那样都代码和html代码混在一起,难以维护。
81.什么是soap,有哪些应用。
答:soap(simple object access protocol )简单对象访问协议,是在分散或分布式的环境中交换信息并执行远程过程调用的协议,是一个基于xml的协议。使用soap,不用考虑任何特定的传输协议(最常用的还是http协议),可以允许任何类型的对象或代码,在任何平台上,以任何一种语言相互通信。这种相互通信采用的是xml格式的消息。
82.c#中 property 与 attribute的区别,他们各有什么用处,这种机制的好处在哪里?
- attribute是microsoft .net framework文件的元数据,可以用来向运行时描述你的代码,或者在程序运行的时候影响应用程序的行为。attribute是派生于system.attribute类之下,它的主要作用是描述
- property是面向对象编程的基本概念,提供了对私有字段的访问封装,在c#中以get和set访问器方法实现对可读可写属性的操作,提供了安全和灵活的数据访问封装。
83.xml 与 html 的主要区别
- xml是html的补充,而不是html的替代品,xml和html是两种不同用途的语言。
- xml是被设计用来描述数据的,重点是:什么是数据,如何存放数据。而html是被设计用来显示数据的,重点是:显示数据以及如何显示数据更好上面。
- xml是*的、可以扩展的,xml标记并不是预先规定好的,你必须创造你自xml标记并不是,而在html文档中必须使用规则中定义好的标记
- xml是区分大小写字母的,html不区分。
- 在html中,如果上下文清楚地显示出段落或者列表键在何处结尾,那么你可以省略</p>或者</li>之类的结束 标记。在xml中,绝对不能省略掉结束标记。
- 在xml中,拥有单个标记而没有匹配的结束标记的元素必须用一个 / 字符作为结尾。这样分析器就知道不用 查找结束标记了。
- 在xml中,属性值必须封装在引号中。在html中,引号是可用可不用的。
- 在html中,可以拥有不带值的属性名。在xml中,所有的属性都必须带有相应的值。
84.c#中的三元运算符是?
答:?:。
85.当整数a赋值给一个object对像时,整数a将会被?
答:装箱。
86.类成员有5种可访问形式?
public
private
protected
internal
protected internal
87.public static const int a=1;这段代码有错误么?是什么?
答:const表现的很像静态变量,它们对类的每个实例都是可见的,而且即使没有类的实例它们也可以使用,而与静态变量不同的是它没有自己的存储位置,而是在编译时被编译器替换,因此它不能声明为static。
88.float f=-123.567f; int i=(int)f;i的值现在是 -123
将f的值强制转换成int型,也就是将小数点后面的部分直接截取,保留整数部分。
89.委托声明的关键字是 delegate。
91.在asp.net中所有的自定义用户控件都必须继承自 control。
92.在.net中所有可序列化的类都被标记为 [serializable]。
93.在.net托管代码中我们不用担心内存漏洞,这是因为有了gc垃圾回收机制。
94.下面的代码中有什么错误吗?_______
using system;
class a
{
public virtual void f(){
console.writeline("a.f");
}
abstract class b:a
{
public abstract override void f();
}
答:abstract override 是不可以一起修饰.
95.当类t只声明了私有实例构造函数时,则在t的程序文本外部,不可以从t派生出新的类,因为子类无法调用父类的构造函数,不可以直接创建t的任何实例。
96.switch语句的格式
switch (1 + 1)
{
case 1:
console.writeline("wrong");
break;
case 2:
console.writeline("right");
break;
default:
console.writeline("jiaoyanqing");
break;
}
97.在.net中,类system.web.ui.page 可以被继承么?
答:可以。
98..net的错误处理机制是什么?
答:.net错误处理机制采用try->catch->finally结构,发生错误时,层层上抛,直到找到匹配的catch为止。
异常:它是程序中的运行时错误,它违反了一个系统约束或应用程序约束,或出现了在正常操作时未预料的情形,如果程序没有提供处理该异常的代码,系统会挂起这个程序。
即使在try块中有return语句,finally块也总是会在返回到调用代码之前执行。
99.利用operator声明且仅声明了==,有什么错误么?
答:要同时修改equale和gethash() ? 重载了"==" 就必须重载 "!="
100. 62-63=1 等式不成立,请移动一个数字(不可以移动减号和等于号),使得等式成立,如何移动?
答案:62移动成2的6次方
105.对于这样的一个枚举类型:enum color : byte { red, green, blue, orange };
答:string[] ss = enum.getnames(typeof(color));
array array = enum.getvalues(typeof(color));
107.c#可否对内存进行直接的操作?
答:c#可以直接对内存进行操作。但是默认情况下,为了保持类型安全,c#不支持指针运算。不过,通过使用 unsafe 关键字,可以定义可使用指针的不安全上下文。在不安全的上下文中,类型可以是指针类型以及值类型或引用类型。
108.ado.net相对于ado等主要有什么改进?
- ado.net不依赖于数据提供程序,而是使用.net托管提供的程序。
- 不使用com
- 不在支持动态游标和服务器端游
- 可以断开connection而保留当前数据集可用
- 强类型转换
- xml支持
110.大概描述一下asp.net服务器控件的生命周期
答:初始化 加载视图状态 处理回发数据 加载 发送回发更改通知 处理回发事件 预呈现 保存状态 呈现 处置 卸载
111.匿名内部类是否可以继承其它类,是否可以实现接口?
答:不能,可以实现接口
113.,&和&&的区别。
&是位运算符,表示按位与运算,&&是逻辑运算符,表示逻辑与(and).
114.hashmap和hashtable的区别。
答:hashmap是hashtable的轻量级实现(非线程安全的实现),他们都完成了map接口,主要区别在于hashmap允许空(null)键值(key),由于非线程安全,效率上可能高于hashtable.
116.重载方法可以改变返回值的类型?
117.error和exception有什么区别?
答:error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。不可能指望程序能处理这样的情况。
exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不会发生的情况。
118.<%# %> 和 <% %> 有什么区别?
答:<%# %>表示绑定的数据源
<% %>是服务器端代码块
120.重载与覆盖的区别?
- 方法的覆盖是子类和父类之间的关系,是垂直关系;方法的重载是同一个类中方法之间的关系,是水平关系
- 覆盖是一个方法或一对方法产生关系;方法的重载是多个方法之间的关系。
- 覆盖要求参数列表相同;重载要求参数列表不同。
- 覆盖关系中,调用那个方法体,是根据对象的类型(对象对应存储空间类型)来决定;重载关系,是根据调用时的实参表与形参表来选择方法体的。
125.分析以下代码。
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是一模一样的话,可以正确使用连接池。不过一模一样的意思是,连字符的空格数,顺序完全一致。
127.什么是wse?目前最新的版本是多少?
答:wse (web service extension) 包来提供最新的web服务安全保证,目前最新版本2.0。
129.下面的例子中
class a
{
public static int x;
static a()
{
x = b.y + 1;
}
}
class b
{
public static int y = a.x + 1;
static b() { }
}
static void main(){
console.writeline("x={0},y={1}", mytest.a.x, mytest.b.y);
}
产生的输出结果是什么?
答:x=2,y=1;
以上所有题目都是个人整理的,如有发现错误或者不理解的欢迎留言指出!!!
上一篇: 加密保护网盘文件防止私密资料泄露
下一篇: ae怎么制作文字变换的动画效果?