.Net框架程序设计(一)----进阶
类别: ASP.NET教程
Q1:值类型和引用类型的差别
Q2:值类型的装箱和拆箱
Answer:
装箱是将一个值类型转换为一个引用类型。例如:在ArrayList中add一个结构体的实例。
步骤:
1 从托管堆上为引用类型分配内存。内存的大小为值类型本身的大小加上其他的空间包括一个方法表和一个SyncBlockIndex
2 值类型的字段被复制到托管堆上新分配的对象的内存中
3 返回托管堆中新分配对象的地址作为该对象的引用。
拆箱是为了获得托管堆上对象的元素到栈空间的值类型中。
1获取在托管堆上的被装相的值类型的地址
2从托管堆上复制到栈上的值类型中
用到DirectCast和CType静态方法
Q3:DirectCast和CType的区别
CType在转型比DirectCast强。比如:一个Int32的值类型装箱为Object,拆箱的时候DirectCast只能从Object转型为Int32(作为拆箱的步骤可能更加安全--没有多的转型),而CType则可以从Object转型为Int16(包括了拆箱和转型2个动作)
Q4:类型构造器和实例构造器的区别
Q5:MemberwiseClone浅拷贝过程
uMemberwiseClone创建与当前实例相同类型的新实例,然后复制原始对象的非静态字段。如果字段为值类型的则为则对该字段执行逐位复制。如果字段是引用类型,则复制该引用但不复制被引用的对象;这样,原始对象中的引用和复本中的引用指向同一个对象。
如何实现深拷贝?
实现IClonable接口,Override父类的Clone()函数
Public Function Clone() As Object Implements IClonable
一般的方法:New一个要clone的新对象,将原对象中成员的值赋给新对象的成员,返回该新对象的引用。
较好的办法:将对象序列化到一个System.IO.MemoryStream中,然后立即对该内存流执行反序列化,从而得到一个新的对象。
Q6:Module与Class的区别
Module实际上也是一种特殊的Class。该类的保护级是Friend,该类不包含任何实例构造器,可以防止创建它的实例,方法和变量都声明为Shared。
使用Module是为了实现模块外部代码对模块中的成员的访问。2来是为了早期VB代码移植的方便。
Q7:VB.Net中的参数传递
有两种一种是按值传递ByVal,一种是按引用传递ByRef。按值传递时候会拷贝一份原参数,引用则相当于别名。
Q8:Structure和Class的区别
1 结构是值类型,其实例是在栈上面分配的;而类的实例是在堆上分配的,其引用是在栈空间上。
2 结构不能被继承,类可以被继承。
3 结构的默认成员都为Public,并且其成员没有Protected,不能给变量声明指定初始值,不能定义默认拷贝构造函数和数组初始大小 ;类的变量和常量是Private,其他成员是Public
4 结构从不终止,不会调用Finalize方法;
创建一个Class的实例和创建一个Structure实例的区别
结构是值类型,其实例是在栈上面分配的;而类的实例是在堆上分配的,其引用是在栈空间上。
Q9:如何保证系统中只有一个程序的实例在运行
1 首先获得当前程序在系统中的进程
2 用该进程的名称为参数,从系统中取得与该进程名称相等的所有存在的进程放在Process数组里面。
3 循环该Process数组,如果有Process的执行文件名和当前产生Process的文件名。如果有,则表明工程已经运行,退出即可,没有的话则继续执行。
Q:重写Overrides与重载Overload的区别
Overloads是同一个类中对同名函数不同参数的重载
Overrides是继承类中对父类中标示为Overridable的函数的重写,实现该函数在继承类中特有的功能
Q:Shadows的作用?
当继承类中的方法被声明为Shadows的时候,会使父类中所有与该方法同名的函数被屏蔽掉,不继承在子类中
Q:抽象类(MustInherit-MustOverride)与接口(的区别
抽象类不能被实例化只能被他的继承类实现,接口也不能被实例化,只能被Implements。
抽象类除了方法会MustOverride修饰外,其他和一般的类没有区别;接口的成员只能有嵌套类型、方法、属性和事件。
Q:Equals
Q:String和StringBuilder区别
这个区别有点类氏于JAVA中的String和StringBuffer的区别。
Q:模拟一个ComboBox接口?
Q:标准事件处理程序
系统实例化一个有反映能力的学生,让他去逛商场,这个时候他有可能碰到很多人,当他看到MM的时候,他会流鼻血。
Module Module1
Class CStudent
Public Event SeeingMM
Sub Shopping
RaiseEvent SeeingMM()
End Sub
End Class
Sub stu_SeeingMM() Handles stu.SeeingMM ‘我们定义这个学生看到MM这个事件发生的
‘时候他就流鼻血
Console.Writeline(“流碧血”)
End Sub
WithEvents stu As New CStudent ‘1 系统实例化一个有反映能力的学生
Sub Main()
Stu.Shopping() ‘2 让他去逛商场,
End Sub
End Module
Q:抽象类(MustInherit-MustOverride)与接口(的区别
Q:抽象类(MustInherit-MustOverride)与接口(的区别
Q2:值类型的装箱和拆箱
Answer:
装箱是将一个值类型转换为一个引用类型。例如:在ArrayList中add一个结构体的实例。
步骤:
1 从托管堆上为引用类型分配内存。内存的大小为值类型本身的大小加上其他的空间包括一个方法表和一个SyncBlockIndex
2 值类型的字段被复制到托管堆上新分配的对象的内存中
3 返回托管堆中新分配对象的地址作为该对象的引用。
拆箱是为了获得托管堆上对象的元素到栈空间的值类型中。
1获取在托管堆上的被装相的值类型的地址
2从托管堆上复制到栈上的值类型中
用到DirectCast和CType静态方法
Q3:DirectCast和CType的区别
CType在转型比DirectCast强。比如:一个Int32的值类型装箱为Object,拆箱的时候DirectCast只能从Object转型为Int32(作为拆箱的步骤可能更加安全--没有多的转型),而CType则可以从Object转型为Int16(包括了拆箱和转型2个动作)
Q4:类型构造器和实例构造器的区别
Q5:MemberwiseClone浅拷贝过程
uMemberwiseClone创建与当前实例相同类型的新实例,然后复制原始对象的非静态字段。如果字段为值类型的则为则对该字段执行逐位复制。如果字段是引用类型,则复制该引用但不复制被引用的对象;这样,原始对象中的引用和复本中的引用指向同一个对象。
如何实现深拷贝?
实现IClonable接口,Override父类的Clone()函数
Public Function Clone() As Object Implements IClonable
一般的方法:New一个要clone的新对象,将原对象中成员的值赋给新对象的成员,返回该新对象的引用。
较好的办法:将对象序列化到一个System.IO.MemoryStream中,然后立即对该内存流执行反序列化,从而得到一个新的对象。
Q6:Module与Class的区别
Module实际上也是一种特殊的Class。该类的保护级是Friend,该类不包含任何实例构造器,可以防止创建它的实例,方法和变量都声明为Shared。
使用Module是为了实现模块外部代码对模块中的成员的访问。2来是为了早期VB代码移植的方便。
Q7:VB.Net中的参数传递
有两种一种是按值传递ByVal,一种是按引用传递ByRef。按值传递时候会拷贝一份原参数,引用则相当于别名。
Q8:Structure和Class的区别
1 结构是值类型,其实例是在栈上面分配的;而类的实例是在堆上分配的,其引用是在栈空间上。
2 结构不能被继承,类可以被继承。
3 结构的默认成员都为Public,并且其成员没有Protected,不能给变量声明指定初始值,不能定义默认拷贝构造函数和数组初始大小 ;类的变量和常量是Private,其他成员是Public
4 结构从不终止,不会调用Finalize方法;
创建一个Class的实例和创建一个Structure实例的区别
结构是值类型,其实例是在栈上面分配的;而类的实例是在堆上分配的,其引用是在栈空间上。
Q9:如何保证系统中只有一个程序的实例在运行
1 首先获得当前程序在系统中的进程
2 用该进程的名称为参数,从系统中取得与该进程名称相等的所有存在的进程放在Process数组里面。
3 循环该Process数组,如果有Process的执行文件名和当前产生Process的文件名。如果有,则表明工程已经运行,退出即可,没有的话则继续执行。
Q:重写Overrides与重载Overload的区别
Overloads是同一个类中对同名函数不同参数的重载
Overrides是继承类中对父类中标示为Overridable的函数的重写,实现该函数在继承类中特有的功能
Q:Shadows的作用?
当继承类中的方法被声明为Shadows的时候,会使父类中所有与该方法同名的函数被屏蔽掉,不继承在子类中
Q:抽象类(MustInherit-MustOverride)与接口(的区别
抽象类不能被实例化只能被他的继承类实现,接口也不能被实例化,只能被Implements。
抽象类除了方法会MustOverride修饰外,其他和一般的类没有区别;接口的成员只能有嵌套类型、方法、属性和事件。
Q:Equals
Q:String和StringBuilder区别
这个区别有点类氏于JAVA中的String和StringBuffer的区别。
Q:模拟一个ComboBox接口?
Q:标准事件处理程序
系统实例化一个有反映能力的学生,让他去逛商场,这个时候他有可能碰到很多人,当他看到MM的时候,他会流鼻血。
Module Module1
Class CStudent
Public Event SeeingMM
Sub Shopping
RaiseEvent SeeingMM()
End Sub
End Class
Sub stu_SeeingMM() Handles stu.SeeingMM ‘我们定义这个学生看到MM这个事件发生的
‘时候他就流鼻血
Console.Writeline(“流碧血”)
End Sub
WithEvents stu As New CStudent ‘1 系统实例化一个有反映能力的学生
Sub Main()
Stu.Shopping() ‘2 让他去逛商场,
End Sub
End Module
Q:抽象类(MustInherit-MustOverride)与接口(的区别
Q:抽象类(MustInherit-MustOverride)与接口(的区别
- 上一篇: .NET中的设计模式二:单件模式
- 下一篇: .NET框架类命名空间
-= 资 源 教 程 =-
文 章 搜 索