[英]String vs. Object type Constructor
public class App {
public static void main(String[] args) {
ConTest conTest = new ConTest(null);
}
POJO:
public class ConTest {
private String a;
private Object b;
public ConTest(Object b) {
System.out.println("Object" + b);
}
public ConTest(String a) {
System.out.println("String :" + a);
}
}
当我运行这段代码时,它总是调用具有String
参数的构造函数。 为什么?
null
可以传递给两个构造函数。
然而,一个String
参数是不是一个更具体的Object
参数(因为String
是一个子类的Object
),和重载解析过程的方法更喜欢(在您的案件或构造函数)的方法,更具体的参数类型。
如评论中所述,如果要强制调用接受Object
的构造函数,则可以将null
强制转换为Object
:
ConTest conTest = new ConTest((Object)null);
原因是存在多种适合调用的拟合方法(在这种情况下为构造函数)。 如果有更多的拟合方法用于方法调用,则始终采用最具体的方法。 在这种情况下, String
比Object
更具体。 这可以在继承链中看到。 String
继承自Object
如果有两个同样特定的方法,那么您的编译器将通过错误消息告诉您The method method(parameter) is ambiguous for the type Class
。 在此示例中可以看到。
public class A {
public static void main(String[] args) {
// compiler complains with:
// The method test(Object) is ambiguous for the type A
test(null);
}
static void test(Object o) {
System.out.println("IN OBJECT");
}
static void test(A a) {
System.out.println("IN A");
}
static void test(B b) {
System.out.println("IN B");
}
class B {
}
}
稍作更改,通过让B
从A
继承,方法test(B)
变得更加具体,因为B
比A
更具体,并且编译器错误消息也消失了。
public class A {
public static void main(String[] args) {
test(null);
}
static void test(Object o) {
System.out.println("IN OBJECT");
}
static void test(A a) {
System.out.println("IN A");
}
static void test(B b) {
System.out.println("IN B");
}
class B extends A{
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.