利用public要害字时,它意味着紧随在public后头的成员声明合用于所有人,出格是合用于利用库的客户措施员。假定我们界说了一个名为dessert的包,个中包括下述单位(若执行该措施时碰着坚苦,请参考第3章3.1.2小节“赋值”):
//: Cookie.java // Creates a library package c05.dessert; public class Cookie { public Cookie() { System.out.println("Cookie constructor"); } void foo() { System.out.println("foo"); } } ///:~
请记着,Cookie.java必需驻留在名为dessert的一个子目次内,而这个子目次又必需位于由CLASSPATH指定的C05目次下面(C05代表本书的第5章)。不要错误地觉得Java无论如何城市将当前目次作为搜索的起点对待。假如不将一个“.”作为CLASSPATH的一部门利用,Java就不会思量当前目次。
此刻,假使建设利用了Cookie的一个措施,如下所示:
//: Dinner.java // Uses the library import c05.dessert.*; public class Dinner { public Dinner() { System.out.println("Dinner constructor"); } public static void main(String[] args) { Cookie x = new Cookie(); //! x.foo(); // Can't access } } ///:~
就可以建设一个Cookie工具,因为它的构建器是public的,并且类也是public的(民众类的观念稍后还会举办更具体的报告)。然而,foo()成员不行在Dinner.java内会见,因为foo()只有在dessert包内才是“友好”的。
1. 默认包
各人大概会惊奇地发明下面这些代码得以顺利编译——尽量它看起来好像已违背了法则:
//: Cake.java // Accesses a class in a separate // compilation unit. class Cake { public static void main(String[] args) { Pie x = new Pie(); x.f(); } } ///:~
在位于沟通目次的第二个文件里:
//: Pie.java // The other class class Pie { void f() { System.out.println("Pie.f()"); } } ///:~
最初大概会把它们看作完全不相干的文件,然而Cake能建设一个Pie工具,并能挪用它的f()要领!凡是的想法会认为Pie和f()是“友好的”,所以不合用于Cake。它们确实是友好的——这部门结论很是正确。但它们之所以仍能在Cake.java中利用,是由于它们位于沟通的目次中,并且没有明晰的包名。Java把象这样的文件看作谁人目次“默认包”的一部门,所以它们对付目次内的其他文件来说是“友好”的。