日期:2013-08-05  浏览次数:20459 次

将派生类对象指派给基类引用。程序要想多态性的处理对象,这是非常基本的部分。
所谓引用就是声明数据类型。
然后就是实例化。“new”.
派生类引用指派给基类引用:point = circle
此时如果调用point的方法,因为将派生类引用指派给基类引用,所以是circle的方法
而不是point的方法。
将基类对象指派给派生类引用(无强制类型转换),会发生语法错误。
派生类引用指派给基类引用,可通过强制类型转换,只有这样才能向那个对象发送未在
基类中出现的消息。(表示调用一个对象的方法和属性)
因为派生类包含与基类对象所有成员对应的成员,但派生类还可能有附加成员。所以,
不进行显式的强制类型转换,就不能将基类的引用指派给派生类引用。option strict
在on 的状态。否则,附加的派生类成员会]进入未定义的状态。

不会实例化任何对象的类,称为抽象类。(mustinherit)
所以,派声类必须覆盖继承抽象的方法和属性,使那些派生类的对象被实例化。
例如:有人让你画一个形状,那么具体画什么形状呢?具体类提供这些细节。
许多良好的面向对象的系统都用mustinherit积累开始以各类层次结构。有时要占据类
层次结构顶部的好几个级别。
关键字mustoverride可将一个方法和属性声明为抽象的。每个派生类必须覆盖所有的
mustoverride方法和属性。使用关键字(overrides)
mustoverride和overridable方法区别在于,后者有具体的方法实现。并允许派生类
覆盖。而前者没有具体实现,并且派生类必须要覆盖其方法和属性。
在面向对对象编程,经常要用到迭代器类。它能便利容器(比如数组)内所有对象
例如:
dim arrayofshapes as cshape() = new shape(2)
arrayofshapes(0) = point
arrayofshapes(0) = circle
arrayofshapes(0) = cylinder(圆柱)
dim shape as cshape
for each shape in arrayofshapes
next
创建和使用接口:
接口指定了类必须是实现的一系列public服务(也就是方法和属性)。
接口要用关键字interface开头,要使用接口,类必须指出实现了自己的implments
接口。
可让接口提供一个属性和方法,让这些类的对象来实现,已返回每个对象的方法或属性。
委托:
在事件通信中,事件发送方类不知道哪个对象或方法将接收到(处理)它引发的事件。
所需要的是在源和接收方之间存在一个媒介(或类似指针的机制)。.NET Framework
定义了一个特殊的类型(Delegate),该类型提供函数指针的功能。
委托是一个可以对方法进行引用的类。与其他的类不同,委托类具有一个签名,并且它只能
对与其签名匹配的方法进行引用。这样,委托就等效于一个类型安全函数指针或一个回调。
委托是一种引用类型,它引用类型的 Shared 方法或对象的实例方法。在其他语言中,
与委托最接近的是函数指针,但函数指针只能引用 Shared 函数,而委托可以引用 Shared
和实例方法。在后一种情况中,委托不仅存储对方法入口点的引用,还存储对用于调用方法
的对象实例的引用。
自己理解:委托其实质就是一个方法的地址,通过它可以找到这个方法,并使用它。
这个在多线程的编程中使用到。
例子:
Delegate Sub MySubDelegate(x as integer)
Protected Sub Test()
Dim c2 As New class2()
' Test the delegate.
c2.DelegateTest()
End Sub

Class class1
Sub Sub1(ByVal x As Integer)
MessageBox.Show("The value of x is: " & CStr(x))
End Sub
End Class

Class class2
Sub DelegateTest()
Dim c1 As Class1
Dim msd As MySubDelegate
c1 = New Class1
' Create an instance of the delegate.
msd = AddressOf c1.Sub1
msd(x) ' Call the method.
End Sub
End Class

委托传递参数:委托的参数传递给class1.sub1的参数,通过这里可以看出。
还有一种方式,但不能传递参数。
dim msd as new methodinvoke(addressof 方法名)
调用时 msd.invoke
委托结合线程使用。