Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/batch-file/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 私有内部类的构造函数应该声明为public还是private?_Java_Constructor_Inner Classes - Fatal编程技术网

Java 私有内部类的构造函数应该声明为public还是private?

Java 私有内部类的构造函数应该声明为public还是private?,java,constructor,inner-classes,Java,Constructor,Inner Classes,这两者之间有实际区别吗 public class OuterClass { private class InnerClass { public InnerClass() {} } } 这个呢 public class OuterClass { private class InnerClass { private InnerClass() {} } } 就其他类而言,不应该这样做,因为内部类被声明为private。他们根本看不见

这两者之间有实际区别吗

public class OuterClass {
    private class InnerClass {
        public InnerClass() {}
    }
}
这个呢

public class OuterClass {
    private class InnerClass {
        private InnerClass() {}
    }
}

就其他类而言,不应该这样做,因为内部类被声明为private。他们根本看不见


它不应该对封闭类产生影响,因为它包含内部类。

从另一个类访问私有成员稍微复杂一些,因为JVM实际上不允许这样做。结果,编译器注入了访问器方法,这会使它稍微慢一点,或者使堆栈跟踪更加复杂

出于这些原因,我把它作为本地包

顺便说一句,
抽象类的构造函数也不需要是
公共的
。它也可以是
保护的
或本地包

private static class A {
    private A() {
        throw new Error();
    }
}
public static void main(String... ignored) {
    new A();
}
打印一个额外的堆栈跟踪元素

Exception in thread "main" java.lang.Error
    at Main$A.<init>(Main.java:8)
    at Main$A.<init>(Main.java:6)
    at Main.main(Main.java:12)
线程“main”java.lang.Error中出现异常 在Main$A(Main.java:8) 在Main$A(Main.java:6) Main.Main(Main.java:12)

将构造函数包设置为本地,第二个构造函数包将消失。

请注意,如果类构造函数标记为
private
,则一些用于编码标准验证的工具(如)可以建议将类标记为
final
。为什么会生成堆栈跟踪的额外行?它是如何工作的?我意识到,只有在我定义为private时,才会出现额外的行。仅适用于受保护的两条线路。那么这意味着定义私有会降低效率?为什么JVM编译器允许定义可见性>=protected的此类类的构造函数?@ukaszRzeszotarski JVM不允许从另一个类进行私有访问。javac所做的工作就是生成可调用的非私有合成方法。这些将获得课程开始的行号。生成的方法调用实方法。它为所有私有成员执行此操作。虽然在解释模式下速度较慢,但一旦优化,额外的方法将被内联,并且对AFAIK没有影响,除非JME系统不够聪明,不能这样做。现在很清楚了。我看到了该类的字节码,真正让我吃惊的是,只有当您尝试实例化该类(例如在主方法中)时,字节码才包含额外的方法。@ukaszRzeszotarski尝试在另一个类中递增
++
+=n
一个私有字段,它应该生成一个方法。;)