举例: 学生:增加,删除,修改,查询 老师:增加,删除,修改,查询 ...
方案1:按照功能分 com.heima.add AddStudent AddTeacher com.heima.delete DeleteStudent DeleteTeacher com.heima.update UpdateStudent UpdateTeacher com.heima.find FindStudent FindTeacher方案2:按照模块分 com.heima.teacher AddTeacher DeleteTeacher UpdateTeacher FindTeacher com.heima.student AddStudent DeleteStudent UpdateStudent FindStudent
本类 同一个包下(子类和无关类) 不同包下(子类) 不同包下(无关类)private Y 默认 Y Yprotected Y Y Ypublic Y Y Y Y
B:类:
抽象修饰符:abstract
用的最多的就是:public
C:成员变量:
状态修饰符:static,final
用的最多的就是:private
D:构造方法:
权限修饰符:private,默认的,protected,public
用的最多的就是:public
E:成员方法:
抽象修饰符:abstract
用的最多的就是:public
F:除此以外的组合规则:
要求:使用已知的变量,在控制台输出30,20,10。class Outer { public int num = 10; class Inner { public int num = 20; public void show() { int num = 30; System.out.println(?); System.out.println(??); System.out.println(???); } }}class InnerClassTest { public static void main(String[] args) { Outer.Inner oi = new Outer().new Inner(); oi.show(); } }
A:案例演示
局部内部类在访问他所在方法中的局部变量必须用final修饰,为什么? 因为当调用这个方法时,局部变量如果没有用final修饰,他的生命周期和方法的生命周期是一样的,当方法弹栈,这个局部变量也会消失,那么如果局部内部类对象还没有马上消失想用这个局部变量,就没有了,如果用final修饰会在类加载的时候进入常量池,即使方法弹栈,常量池的常量还在,也可以继续使用
但是jdk1.8取消了这个事情,所以我认为这是个bug
new 类名或者接口名(){ 重写方法;}
//这里写抽象类,接口都行abstract class Person { public abstract void show();}class PersonDemo { public void method(Person p) { p.show(); }}class PersonTest { public static void main(String[] args) { //如何调用PersonDemo中的method方法呢? PersonDemo pd = new PersonDemo (); }}
按照要求,补齐代码interface Inter { void show(); }class Outer { //补齐代码 }class OuterDemo { public static void main(String[] args) { Outer.method().show(); }}要求在控制台输出”HelloWorld”
联系客服