参见英文答案 > Ambiguous varargs methods4个
我不明白为什么在这里的情况1,它没有给出编译错误,相反在情况2(varargs),它给出了编译错误.任何人都可以详细说明编译器在这两种情况下的差异吗?我经历了很多关于它的帖子,但还不能理解它.

情况1

public class Test {

    public void display(int a) {
        System.out.println("1");
    }

    public void display(Integer a) {
        System.out.println("2");
    }

    public static void main(String[] args) {
        new test().display(0);
    }
}

输出为:1

案例#2

public class Test {

    public void display(int... a) {
        System.out.println("1");
    }

    public void display(Integer... a) {
        System.out.println("2");
    }

    public static void main(String[] args) {
        new test().display(0);
    }
}

编译错误:

The method display(int[]) is ambiguous for the type Test

解决方法

在第一个示例中,display(int)方法在严格调用上下文中调用,而display(Integer)在松散调用上下文中调用(因为需要自动装箱).因此编译器根据JLS选择display(int)方法.调用上下文在这里解释 JLS 5.3. Invocation Contexts

在第二个示例中,两个方法都在松散的调用上下文中调用,因此编译器需要找到最具体的方法JLS 15.12.2.5 Choosing the Most Specific Method.由于int不是Integer的子类型,因此没有最具体的方法,编译器会抛出编译错误.

你可以在Method overload ambiguity with Java 8 ternary conditional and unboxed primitives找到类似编译错误的解释

适用于此案例的部分:

Identifying applicable methods is divided into 3 phases.

The first phase (§15.12.2.2) performs overload resolution without
permitting Boxing or unBoxing conversion,or the use of variable
arity method invocation
. If no applicable method is found during
this phase then processing continues to the second phase.

The second phase (§15.12.2.3) performs overload resolution while
allowing Boxing and unBoxing,but still precludes the use of
variable arity method invocation
. If no applicable method is found
during this phase then processing continues to the third phase.

The third phase (§15.12.2.4) allows overloading to be combined with
variable arity methods,Boxing,and unBoxing.

对于第一个示例,只有display(int)方法在第一个阶段匹配,因此选择它.对于第二个示例,两个方法在第三阶段匹配,因此选择最具体方法算法发挥作用JLS 15.12.2.5 Choosing the Most Specific Method:

m2 is not generic,and m1 and m2 are applicable by variable arity
invocation,and where the first k variable arity parameter types of m1
are S1,…,Sk and the first k variable arity parameter types of m2
are T1,Tk,the type Si is more specific than Ti for argument ei
for all i (1 ≤ i ≤ k). Additionally,if m2 has k+1 parameters,then
the k+1’th variable arity parameter type of m1 is a subtype of the
k+1’th variable arity parameter type of m2.

如前所述,由于int&lt ;: Integer不满足,因此没有最具体的方法.

java – 使用原始类型和包装类的varargs重载时为什么会出现模糊错误?的更多相关文章

  1. ios – Swift:方法重载只在返回类型上有所不同

    我一直在看Swift类,其中定义了两种方法,它们的返回类型不同.我不习惯使用允许这种语言的语言,所以我去寻找描述它如何在Swift中工作的文档.我在任何地方都找不到任何东西.我本来期望在Swift书中有关于它的整个部分.这记录在哪里?

  2. ios – 在Swift中可以重载=运算符吗?

    可以在Swift中使用overload=运算符来接受例如CGFloat参数吗?我的方法(下面)不起作用.(编辑)重要:上面的编码方法确实有效.请seemyanswerbelow解释为什么我认为没有.解决方法对不起,我很难过.对于CGFloat参数,operator=不需要重载,因为Swift中包含了这样的重载.我试图做类似的事情这失败了,因为我无法放弃让XCode显示的错误让我感到困惑.当然,像我原来的问题(下面)中的方法适用于重载运算符.请随时投票以结束此问题.

  3. Swift 运算符重载

    但是现在还有另外一个Swift的特性,你应该知道并且会爱上它,它就是运算符重载。例如:我们在SwiftSpriteKitutilitylibrary代码中使用运算符重载去讲多个CGPoints对象相加,例如下面代码:1234letpt1=CGPointletpt2=CGPointletpt3=pt1+pt2letpt4=pt3*100方便吧?当一个人查看你的代码,他们希望操作符的默认行为,这时候运算符重载会使他们迷惑。幸运的是Swift让你能够定义属于你自己的自定义的运算符。

  4. swift中使用xib

    在OC时代,使用xib来管理界面很简单,但是swift下使用xib有点小复杂。由于项目需要,有一个view需要重复使用,storyboard无法满足需求,使用xib更为简便。总结一下swift中使用xib的注意事项:1.新建cocoatouchclass,xib的file‘sowner设置成对应controller2.由于swift不会自动override父类的init方法,所以如果只是按照第一步来做得话,会报错,因此,我们必须手动添加init方法:以上两个方法必须重载,至于默认构造函数最好也重载:

  5. Swift学习笔记(十二)构造过程

    默认构造器Swift将为所有属性已提供默认值的且自身没有定义任何构造器的结构体或基类,提供一个默认的构造器。构造器的继承和重载跟Objective-C中的子类不同,Swift中的子类不会默认继承父类的构造器。Swift的这种机制可以防止一个父类的简单构造器被一个更专业的子类继承,并被错误的用来创建子类的实例。

  6. Swift 2.0学习笔记Day 39——构造函数重载

    Swift中构造函数可以多个,他们参数列表和返回值可以不同,这些构造函数构成重载。构造函数代理在结构体和类中使用方式是不同,先介绍结构体中构造函数代理。将上一节的示例修改如下:将Rectangle声明为结构体类型,其中也有4个构造函数重载。这种在同一个类型中通过self.init语句进行调用当前类型其它构造函数,其它构造函数被称为构造函数代理。横向代理类似于结构体类型构造函数代理,发生在同一类内部,这种构造函数称为便利构造函数。

  7. Swift 中的 数组排序 和 重载运算符

    数组排序首先拿到一个数组,然后这个是按照数字中Item元素的name属性来排序的代码片段:这个使用的方法是sortInPlace,还有另外一个方法是sort。如果使用了sort,那么原来的数组是不会有任何变化的,使用sortInPlace,会在原来的数组上做修改。还可以简化为:第二种写法没有传统的括号(),使用$0来标记两个$1数组中的对象可读性很好,这是Swift的闭包中很好的一个特性。

  8. Swift 3.构造函数-重载构造函数

    ViewController.swiftPerson.swiftStudent.swift

  9. 《从零开始学Swift》学习笔记Day 39――构造函数重载

    Swift中构造函数可以多个,他们参数列表和返回值可以不同,这些构造函数构成重载。构造函数代理在结构体和类中使用方式是不同,先介绍结构体中构造函数代理。将上一节的示例修改如下:将Rectangle声明为结构体类型,其中也有4个构造函数重载。这种在同一个类型中通过self.init语句进行调用当前类型其它构造函数,其它构造函数被称为构造函数代理。横向代理类似于结构体类型构造函数代理,发生在同一类内部,这种构造函数称为便利构造函数。

  10. swift学习笔记之运算符重载

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部