Java方法为什么会自动调用_为什么自动装箱会使Java中的某些调用变得模棱两可?...

本文详细解释了Java编译器在处理方法重载时的两个解析阶段,第一阶段禁止装箱和拆箱,第二阶段允许但不优先考虑。当存在多个匹配方法时,编译器通过子类型转换选择最具体的方法,而非依据装箱次数。文中通过示例展示了这种情况可能导致的编译歧义。

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

小编典典

当您自己将第一个参数转换为Object时,编译器将匹配该方法而无需使用自动装箱(JLS3 15.12.2):

第一阶段(第15.12.2.2节)执行重载解析,不允许装箱或拆箱转换,也不允许使用可变Arity方法调用。如果在此阶段未找到适用的方法,则处理将继续进行到第二阶段。

如果您没有明确地转换它,它将进入尝试查找匹配方法的第二阶段,允许自动装箱,然后它的确是模棱两可的,因为您的第二个参数可以通过布尔值或对象进行匹配。

第二阶段(第15.12.2.3节)在允许装箱和拆箱的同时执行重载解析,但仍排除使用可变arity方法调用。

在第二阶段,为什么编译器不选择第二种方法,因为没有必要对布尔参数进行自动装箱?因为在找到两种匹配方法之后,仅使用子类型转换来确定这两种方法中最具体的方法,而不用考虑首先进行匹配的装箱或拆箱(第15.12.2.5节)。

另外:编译器不能总是根据所需的自动装箱数量选择最具体的方法。它仍然可能导致模棱两可的情况。例如,这仍然是模棱两可的:

public class Test {

static void f(Object a, boolean b) {}

static void f(int a, Object b) {}

static void m(int a, boolean b) { f(a, b); } // ambiguous

}

请记住,选择匹配方法的算法(编译时步骤2)是固定的,并在JLS中进行了描述。一旦进入第2阶段,就不会选择自动装箱或拆箱。编译器将找到 所有

可访问的方法(在这两种情况下均为这两种方法)和适用的方法(再次是这两种方法),然后才选择最具体的方法,而无需查看装箱/拆箱,此处不明确。

2020-09-09

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值