包
如果所有类都放一起开发,方便易记的类名很快用完,也很容易出现协作时命名冲突的问题。
包是Java提供的一种命名机制,同时也是一种可见性控制机制。
包定义
Java使用文件系统目录存储包,包名必须和目录路径一致,包括大小写
//定义包名,写在Java源文件中的第一条语句
package pkg;
//层次化
package java.awt.img;
包查找与CLASSPATH
Java运行时怎么找到这些包呢?
package MyPack;
3种方式:
1、Java程序运行目录下有MyPack目录
2、CLASSPATH环境变量下有Mypack目录
3、运行程序时通过-classpath选项指明包路径运行
访问保护
而对【非嵌套类】只有2种访问级别
默认级别:只能被同包中的其它类访问。
公有级别:任何其它代码都可访问;要求该类是文件中唯一一个公有类,切文件名要和类名完全一致。
导入包
import java.util.Data;
import java.io.*;//导入整个包
Java隐式地为所有代码都导入了java.lang包,相当于每个源文件开头都添加了
import java.lang.*;
import语句是可选的,也可以选择使用完全限定名来使用类
class MyDate extends java.util.Date{
}
接口
使用interfere创建接口,可用于指定类必须实现哪些功能
定义接口
interface Callback{
void callback(int param);
}
1、如果接口没有修饰符,采用默认访问级别,只有声明接口的包中的其它成员才能访问接口。
2、如果接口声明为public,那么所有代码都可以使用接口,且接口是当前文件中的唯一公有接口,文件名必须和接口同名。
3、JDK 8及以后的版本中,可以为接口创建默认实现。
4、接口中可以声明变量,隐式标识为final和static,所有实现接口的类都不能修改他们,还必须初始化他们。
5、所有方法和变量都隐式声明为public。
实现接口
class Client implements Callback{
public void callback(int p){
System.out.println(p);
}
}
1、实现接口方法时,必须声明为public
2、使用接口调用方法,是在运行时动态查询到方法并执行,和常规方法调用相比占用更多资源,对性能要求苛刻的代码中谨慎使用。
class TestIface{
public static void main(String args[]){
//使用接口调用方法
Callback c = new Client();
//调用的方法是来自对象,而不是类型变量
c.callback(42);
}
}
部分实现:
如果类实现一个接口,但是没有实现所有接口方法,那么必须讲这个类声明为abstract
abstract class Incomplete implements Callback{
void show(){
System.out.println("Good");
}
}
接口中的变量
创建一个包含变量的接口,实现这个接口的类相当于把这些这些变量当作常量导入到类的命名控件下。
interface SharedConstants{
int NO = 0;
int YES = 1;
int NULL = 2;
}
这种用法有争议,仅作介绍
接口的继承
接口可以继承,实现一个子接口,必须实现这个接口的继承链上所有接口的所有方法。
默认接口方法default
【JDK8】才出现
默认方法也称扩展方法
可以为接口的方法提供默认实现
动机:
1、当接口需要增加一个方法,那么实现接口的类必须实现这个方法,导致增加方法会破坏原有代码;
2、提供可选方法。例如有一个接口有一个方法remove,有2个类都实现了这个接口,其中一个类希望他是不可删除的,原来方法就需要写一个remove的空实现。现在有了默认方法,可以在接口默认空实现,或抛出异常,这样类就不用去做空实现了。
public interface MyIF{
//使用default关键字
default String getString(){
return "Default";
}
}
优点:
1、优雅地随时间演进接口
2、提供可选功能,且类不必在不需要该功能时提供占位符实现。
不同接口的同名方法
一个类实现了2个接口,2个接口都有默认方法reset,那么使用方法的顺序如下:
1、类有实现,优先类的实现
2、类没有重写实现,则报错
如果是一个接口继承另外一个接口,且有仙童默认方法,则继承接口的版本更高优先级
//显式调用被继承接口中的默认实现
SuperInterface.super.reset();
9.6 在接口中使用静态方法
【JDK 8】才出现
可以在接口中直接定义静态方法,然后直接调用
public interface MyIF{
static int getDefaultNumber(){
return 0;
}
}
//调用
int a = MyIF.getDefaultNumber();
注意:
1、实现接口的类或子接口不会集成接口中的静态方法。