标签:方式 add 外部类 alt 合规 多级 exti package nts
举例:
学生:增加,删除,修改,查询
老师:增加,删除,修改,查询
...
  方案1:按照功能分
      com.hwh.add
          AddStudent
          AddTeacher
      com.hwh.delete
          DeleteStudent
          DeleteTeacher
      com.hwh.update
          UpdateStudent
          UpdateTeacher
      com.hwh.find
          FindStudent
          FindTeacher
  方案2:按照模块分
      com.hwh.teacher
          AddTeacher
          DeleteTeacher
          UpdateTeacher
          FindTeacher
      com.hwh.student
          AddStudent
          DeleteStudent
          UpdateStudent
          FindStudent
会在当前路径下生成com>hwh>Demo1_Package

先编译Person.java, 在baidu文件夹中生成Person.class
再编译Demo2_Package.java, 在hwh文件夹中生成Demo2_Package.class
再运行Demo2_Package
package com.baidu;
public class Person {
    private String name;
    private int age;
    
    public Person(){}
    public Person(String name,int age){
        this.name = name;
        this.age = age;
    }
    public void setName(String name){
        this.name = name;
    }
    public void setAge(int age){
        this.age = age;
    }
    public String getName(){
        return name;
    }
    public int getAge(){
        return age;
    }
}package com.hwh;
class Demo2_Package {
    public static void main(String[] args) {
        com.baidu.Person p = new com.baidu.Person("张三",23);
        System.out.println(p.getName()+"..."+p.getAge());
    }
}
package com.hwh;
import com.baidu.Person;
//import java.util.Scanner;     //在开发中我们用的都是导入具体的类
import java.util.*;             //*代表通配符,他会到该包下挨个匹配,匹配上就导入
class Demo2_Package {
    public static void main(String[] args) {
        com.baidu.Person p = new com.baidu.Person("张三",23);
        System.out.println(p.getName()+"..."+p.getAge());
    Scanner sc = new Scanner(System.in);
        System.out.println("请输入一个整数");
        int x = sc.nextInt();
        System.out.println(x);
    }
}

| / | 本类 | 同一个包下(子类和无关类) | 不同包下(子类) | 不同包下(无关类) | 
|---|---|---|---|---|
| private | 可 | |||
| 默认 | 可 | 可 | ||
| protected | 可 | 可 | 可 | |
| public | 可 | 可 | 可 | 可 | 
抽象修饰符:abstract
用的最多的就是:public
状态修饰符:static,final
用的最多的就是:private
权限修饰符:private,默认的,protected,public
用的最多的就是:public
抽象修饰符:abstract
用的最多的就是:public
class Demo1_Innerclass {
    public static void main(String[] args) {
        //Inner i = new Inner();
        //i.method();
        //外部类名.内部类名 = 外部类对象.内部类对象
        Outer.Inner oi = new Outer().new Inner();   //创建内部类对象
        oi.method();
    }
}
class Outer{
    private int num = 10;
    class Inner{
        public void method(){
            System.out.println(num);
        }
    }
}运行结果为10
class Demo2_InnerClass {
    public static void main(String[] args) {
        //Outer.Inner oi = new Outer().new Inner();
        //oi.method();
        Outer o = new Outer();
        o.print();
    }
}
class Outer {
    private  int num = 10;
    private class Inner {   //内部类私有
        public void method() {
            System.out.println(num);
        }
    }
    public void print() {
        Inner i = new Inner();
        i.method();
    }
}运行结果为10
class Demo3_InnerClass {
    public static void main(String[] args) {
        Outer.Inner oi = new Outer.Inner();
        oi.method();
    Outer.Inner2.print();
    }
}
class Outer{
    static class Inner{
        public void method(){
            System.out.println("method");
        }
    }
    static class Inner2{
        public static void print(){
            System.out.println("print");
        }
    }
}运行结果为method print
class Demo4_InnerClass {
    public static void main(String[] args) {
        Outer o = new Outer();
        o.method();
    }
}
//局部内部类
class Outer {
    public void method() {
        final int num = 10; //int num = 10 错误: 从内部类中访问本地变量num; 需要被声明为最终类型
        class Inner {
            public void print() {
                System.out.println(num);
            }
        }
        Inner i = new Inner();
        i.print();
    }
    /*public void run() {
        Inner i = new Inner();              //局部内部类,只能在其所在的方法中访问
        i.print();
    }*/
}因为当调用这个方法时,局部变量如果没有用final修饰,他的生命周期和方法的生命周期是一样的,当方法弹栈,这个局部变量也会消失,那么如果局部内部类对象还没有马上消失想用这个局部变量,就没有了,如果用final修饰会在类加载的时候进入常量池,即使方法弹栈,常量池的常量还在,也可以继续使用
但是jdk1.8取消了这个事情,虽然取消,如果在书写代码时候,没有手动添加,系统底层也会默给你final
class Demo1_NoNameInnerClass {
    public static void main(String[] args) {
        Outer o = new Outer();
        o.method();
    }
}
interface Inter {
    public void print();
}
class Outer {
    class Inner implements Inter {
        public void print() {
            System.out.println("print");
        }
    }
    public void method(){
        Inner i = new Inner();
        i.print();
        
    }
}有名字的内部类
运行结果为print
修改method()
public void method(){
        //Inner i = new Inner();
        //i.print();
        //new Inner().print();
        //Inter i = new Inner();            //父类引用指向子类对象
        
        new Inter() {                       //实现Inter接口
            public void print() {           //重写抽象方法
                System.out.println("print");
            }
        }.print();     //整个代表Inter()的子对象,调用print()方法
    }运行结果为print
class Demo2_NoNameInnerClass {
    public static void main(String[] args) {
        Outer o = new Outer();
        o.method();
    }
}
interface Inter {
    public void show1();
    public void show2();
}
//匿名内部类只针对重写一个方法时候使用, 多个方法时为避免冗余使用有名字类
class Outer {
    public void method() {
        /*new Inter(){
            public void show1() {
                System.out.println("show1");
            }
            public void show2() {
                System.out.println("show2");
            }
        }.show1();
        new Inter(){
            public void show1() {
                System.out.println("show1");
            }
            public void show2() {
                System.out.println("show2");
            }
        }.show2();*/
        Inter i = new Inter(){
            public void show1() {
                System.out.println("show1");
            }
            public void show2() {
                System.out.println("show2");
            }
            /*public void show3() {
                System.out.println("show3");
            }*/
        };
        i.show1();    //编译时看父类接口中的show1(), 运行时看子类对象中的show2()方法
        i.show2();
        //i.show3();                        //匿名内部类是不能向下转型的,因为没有子类类名
    }
}运行结果为show1 show2
有名字类
        //这里写抽象类,接口都行
        abstract class Person {
            public abstract void show();
        }
    
        class PersonDemo {
            public void method(Person p) { //Person p = new Student() 
                p.show();
            }
        }
    
        class PersonTest {
            public static void main(String[] args) {
                //如何调用PersonDemo中的method方法呢?
                PersonDemo pd = new PersonDemo ();
                pd.method(new Student());
            }
        }匿名类
    //这里写抽象类,接口都行
        abstract class Person {
            public abstract void show();
        }
    
        class PersonDemo {
            /*
            Person p = new new Person(){     //父类引用指向子类对象
                    public void show(){
                        System.out.println("show");
                    }
                }
            */
            public void method(Person p) {  
                p.show();
            }
        }
    
        class PersonTest {
            public static void main(String[] args) {
                //如何调用PersonDemo中的method方法呢?
                PersonDemo pd = new PersonDemo ();
                pd.method(new Person(){     //匿名内部类当作参数传递(本质把匿名内部类看作一个对象)
                    public void show(){
                        System.out.println("show");
                    }
                });
            }
        }标签:方式 add 外部类 alt 合规 多级 exti package nts
原文地址:https://www.cnblogs.com/albieh/p/12242424.html