后期绑定

本文深入探讨Java中的动态绑定概念,解释了如何通过虚拟机确定方法的实际调用版本,并通过示例代码展示了重载与覆盖方法的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

绑定指的是一个方法的调用与方法所在的类(方法主体)关联起来分为:动态绑定(在对象中安插某种信息)、静态绑定

java动态绑定的过程:(static、fianal(包括私有方法和成员变量)属于前期绑定 成员变量为前期绑定。运行时(动态)绑定针对的范畴只是对象的方法。将方法声明为final类型的一是为了防止方法被覆盖,二是为了有效的关闭java中的动态绑定

虚拟机提取对象的实际类型的方法表

虚拟机搜索方法签名

调用方法

Parent p = new Children();
其具体过程细节如下:
1:编译器检查对象的声明类型和方法名。假设我们调用x.f(args)方法,并且x已经被声明为C类的对象,那么编译器会列举出C类中所有的名称为f的方法和从C类的超类继承过来的f方法
2:接下来编译器检查方法调用中提供的参数类型。如果在所有名称为f 的方法中有一个参数类型和调用提供的参数类型最为匹配,那么就调用这个方法,这个过程叫做“重载解析”  
3:当程序运行并且使用动态绑定调用方法时,虚拟机必须调用同x所指向的对象的实际类型相匹配的方法版本。假设实际类型为D(C的子类),如果D类定义了f(String)那么该方法被调用,否则就在D的超类中搜寻方法f(String),依次类推

重载函数的实际调用版本由编译器绑定决定,而覆盖函数的实际调用版本由动态绑定决定:

class Base{  
    public void foo(Base x){  
        System.out.println("Base.Base");  
    }  
      
    public void foo(Derived x){  
        System.out.println("Base.Derived");  
    }  
}  
class Derived extends Base{  
  public void foo(Base x){  
        System.out.println("Derived.Base");  
    }  
      
    public void foo(Derived x){  
        System.out.println("Derived.Derived");  
    }  
}  
class Main{  
    public static void whichFoo(Base arg1, Base arg2){  
        arg1.foo(arg2);  
    }  
  
    public static void main(String[] args)}{  
        Base b = new Base();  
        Derived d = new Derived();  
      
        whichFoo(b,b);  
        whichFoo(b,d);  
        whichFoo(d,b);  
        whichFoo(d,d);              
    }  
}  

则此处whichFoo重载方法编译器决定:形参arg2的类型是Base,因此不管arg2实际引用的是什么类型,arga.foo(arg2)匹配的都是public void foo(Base x)

覆盖方法的实际版本由动态绑定决定:根据实际引用的类型决定用Base还是Derived版本中的foo(Base x)函数

在VB6.0中,如果你遇到的是后期绑定(Late Binding)的情况,即在运行时确定对象的具体类型,那么处理字典可能会有所不同,因为它依赖于具体的对象实例而不是预定义的类型。以下是后期绑定字典的一般情况: 1. **动态获取属性**:如果你有一个字典变量,但实际上是在运行时才知道其实际类型(可能是Dictionary或其他实现了IUnknown接口的自定义类),你可以通过反射API(如`IsObject`, `GetInterface`等)来访问字典的属性和方法。例如,查找`Item`方法: ```vb Dim obj As Object Set obj = ... ' 获取到未知类型的字典对象 If Not IsNull(obj) Then Dim dictProp As IUnknown If obj.GetInterface(vbDictionary, dictProp) Then Dim key As Variant If dictProp.InvokeMethod("Item", Array(key), ByValVar outValue) Then ' 使用outValue处理字典内容 End If Else ' 对象不是字典类型 End If End If ``` 2. **强制转换**:如果能确定字典是从特定类型派生的,你可以尝试将其强转为那个类型,以便进行更精确的操作: ```vb Dim obj As Object Set obj = ... ' 获取到字典对象 Dim typedDict As Dictionary On Error Resume Next ' 防止转换失败导致错误 Set typedDict = DirectCast(obj, Dictionary) On Error GoTo 0 If Not (typedDict Is Nothing) Then ' 现在可以像正常字典那样处理typedDict Else ' 字典对象类型转换失败 End If ``` 3. **异常处理**:在后期绑定中,处理字典时需要考虑到可能出现的类型不匹配或无效操作,因此适当的错误处理至关重要。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值