关于java语言当中的包机制:
? 1.包又被称为package,java中引入package这种语法机制主要是为了方便程序的管理。
不同功能的类被分门别类放到不同的软件包当中,查找比较方便,管理比较方便,易维护。
? 2.怎么定义package呢?
???? —在java源程序的第一行上编写package语句。
???? —package只能编写一个语句
???? —语法结构:
???????????? package 包名;
?3.包名的命名规范:
????? 公司域名倒序+项目名+模块名+功能名;
采用这种方式重名的纪律较低。因为公司域名具有全球唯一性。
?4.包名要求全部小写,包名也是标识符,必须遵守标识符的命名规则。
?5.一个包对应一个目录
?例如:com.bjpowernode.javase.day;??? //4个目录【目录之间用.隔开】
?6.使用package机制后应该怎么编译?怎么运行呢?
???? —使用package机制后,类名不再是Test01了,类名是com.bjpowernode.javase.day.Test01;
???? —编译:javac java源文件路径 (在硬盘上生成了一个class文件:Test01.class)
???? —手动方式创建目录,将Test01.class字节码文件放到指定的目录下
???? —运行:java com.bjpowernode.javase.day.Test01
??? —另一种方式(编译+运行):
???????? *编译: javac? —d .编译之后存放路径? java源文件路径
????????????????? javac 负责编译的命令
????????????????? -d???? 带包编译
????????????????? .??????? 代表编译之后生成的东西放到当前目录下(点代表当前目录)
???????? *例如:将F:\Hellow.java文件编译之后放到C:\目录下
????????????? java —d C:\ F:\Hellow.java
??????? *javac —d .*.java
?????????????? 将当前路径中*.java编译之后存放到当前目录下
??????? *运行:JVM的类加载器ClassLoader默认从当前路径下下载。保证DOS命令窗口的路径先切换到com所在的路径,执行com.bjpowernode.javase.day.Test01
java.lang.*;不需要手动引入,系统自动引入。
?lang:language语言包,是java语言的核心类,不需要手动引入。
?import语句用来完成导入其他类,同一个包下的类不需要导入,不在同一个包下需要手动导入。
?import语法格式:
???? import 类名
???? import 包名.*
?import语句需要编写到package语句之下,class语句之上
?什么时候需要import?
??? 不是java.lang包下,并且不再同一个包下的时候,需要使用import进行引入。
访问控制权限修饰符:
?? 1.访问控制权限修饰符来控制元素的访问范围
?? 2.访问控制权限修饰符包括:
???? public????????????????????? 表示公开的,在任何位置都可以访问
???? protected??????????????? 同包 子类
???? 缺省???????????????????????? 同包
???? private???????????????????? 表示私有的,只能在本类中访问
? 3.访问控制权限修饰符可以修饰类,方法,变量
? 4.当某个数据只希望子类使用时,使用protected进行修饰。
? 5.修饰符的范围:
????? private<缺省<protected<public
? 6.类只能采用public和缺省的修饰符进行修饰【内部类除外】
?关于Java语言当中final关键字:
??? 1.final是一个关键字,表示最终的,不可变的
??? 2.final修饰的类无法被继承
??? 3.final修饰的方法无法被覆盖
??? 4.final修饰的变量“一旦”赋值之后,不可重新赋值【不可二次赋值】
??? 5.final修饰的实例变量,必须手动赋值,不能采用系统默认值(实例变量有默认值,final修饰的变量一旦赋值不能重新赋值)
??? 6.final修饰的引用,一旦指向某个对象之后,不能再指向其他对象,那么被指向的对象无法被垃圾回收器回收
final修饰的引用虽然指向某个对象之后不能指向其他对象,但是所指向的对象内部的内存是可以被修改的。
??? 7.final修饰的实例变量,一般和static联合使用,被称为常量。
?????? 常量的定义语法格式:public static final 类型 常量名 = 值;
?????? java程序中要求所有常量的名字全部大写,每个单词之间使用下划线连接
?//创建用户对象
User u = new User(100); //User u=0X1234
//又创建了一个新的User对象
//程序执行到此处表示以上对象已变成垃圾数据,等待垃圾回收器的回收
?u = new User(200); //u = 0X2586
//创建用户对象
?final User user = new User(30);
?//user = new User(50); // 编译错误
User.id=50; //编译通过
实例变量采用final赋值
? 第一种方式:
???? final int age = 10;? //直接赋值
?第二种方式:
?? final int num;
?? public 类名(){
???? this.num = 100;
?? }???????????????????????????????? //采用构造方法赋值
三、super关键字
1.super是一个关键字,全部小写
?2.super和this对比学习:
?? this:
????? this能出现在实例方法和构造方法当中
????? this的语法时:”this.“ ”this()“
????? this不能使用在静态方法中
????? this.大部分情况下是可以省略的
????? this.什么时候不能省略呢?在区分局部变量和实例变量的时候不能省略
???????? public void setName(String name){
????????????? this.name=name;
????????? }
?????? this()只能出现在构造方法第一行,通过当前的构造方法去调用”本类“中其他的构造
方法,目的是:代码复用
??? super?????
???? super能出现在实例方法和构造方法当中
???? super的语法时:”super.“ ”super()“
???? super不能使用在静态方法中
???? super.大部分情况下是可以省略的
????? super.什么时候不能省略呢?
??????? 父中有,字中又有,如果想在字中访问”父类特征“,super.不能省略
????? super()只能出现在构造方法第一行,通过当前的构造方法去调用”父类“中的构造
方法,目的是:创建子类对象的时候,先初始化父类型特征
?? 3.super()
???????? 表示通过子类的构造方法调用父类的构造方法。
模拟现实世界的这种场景,要想有儿子,需要先有父亲
? 4.结论:当一个构造方法第一行既没有this(),又没有super()的话,默认会有一个super();表示通过当前子类的构造方法调用父类的无参数构造方法。所以必须保证父类无参数的构造方法是存在的。
? 5.注意:super()和this()不能共存,他们都是只能出现在构造方法第一行
? 6.无论是怎么判断,父类的构造方法是一定会执行。(百分之百的)
? 7.在java语言当中不管是new什么对象,最后的Obiect类的无参数构造方法一定会执行。(Object类的无参数构造方法是处于”栈顶部“)
?????? 栈顶的特点:
???????????? 最后调用但是最先执行结束。后进先出原则。
? 8.super代表的是"当前对象(this)"的“父类型特征。
? 9.在构造方法执行的过程中一连串调用了父类的构造方法,父类的构造方法又继续向下调用它的父类的构造方法,但是实际上对象只创建了一个。
?10.super(实参)到底是干啥的?
???????? super(实参)的作用是:初始化当前对象的父类型特征。并不是创建对象,实际上对象只创建了1个。
?11.super关键字代表什么呀?
??????? super关键字代表的就是“当前对象”的那部分父类型特征
java是怎么区分子类和父类的同名属性的?
?? this.name?? 当前对象的name属性
?? super.naem? 当前对象的父类型特征中的name属性
?super不是引用,super也不保存内存地址,super也不指向任何对象
?super只是代表当前对象内部的那一块父类型的特征
?在父和子中有同名的属性,或者说有相同的方法,如果此时想在子类中访问父中的数据,必须使用"super"加以区分
?super.属性名????????????? 【访问父类的属性】
?super.方法名(实参) 【访问父类的方法】
?super(实参)????????????? 【调用父类的构造方法】