将派生类对象指派给基类引用。程序要想多态性的处理对象,这是非常基本的部分。 所谓引用就是声明数据类型。 然后就是实例化。“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 委托结合线程使用。

|