Java学习笔记总结
静态初始化块
1.构造方法,用于对象的初始化
2.静态初始化块,用于类的初始化操作,在静态初始化块中不能直接访问非static成员
参数传值机制
1.方法中所有参数都是“值传递”,也就是“传递的都是值的副本”。
基本数据类型参数的传值
传递的是值的副本,副本改变不会影响原值
引用类型参数的传值
(解释:类似C/C++的指针,它以特殊的方式指向对象实体(具体的值),这类变量声明时不会分配内存,只是存储了一个内存地址)
传递的是值的副本。但是引用类型指的是“对象的地址”。因此,副本和原参数都指向了同一个地址,改变“副本指向地址对象的值,也意味着原参数指向地址对象的值的改变。”
单继承与多继承
- Java的接口可以多继承,类只有单继承。
==与equals的区别
-
==:代表比较双方是否相同,如果是基本类型则表示值相等;如果是引用类型则表示地址相等即是同一个对象。
-
equals:对象的内容相等(一般会重写)
super和this
-
this():用于类的构造函数重载,一个构造函数使用this(),相当于“继承”了该构造函数。
-
super():直接父类对象的引用。可以通过super来访问父类中被子类覆盖的方法或属性。
-
super.funtuin():表示子类调用父类的普通方法;默认情况,子类会隐式调用父类构造方法。可以这样理解:子类的构造器会先默认调用父类的构造器(使用super()方法实现),以此上溯。相同的形式还有静态初始化块也是如此形式。
-
super 永远位于构造器的首位
构造器的调用顺序
构造方法的第一句总是:super(…)来调用父类对应的构造方法。所以,流程就是:先向上追溯到object,然后在依次向下执行类的初始化块和构造方法,直到当前子类。
多态
多态的必要条件:
- 要有继承
- 要有重写
- 父类引用指向子类对象
多态有个特点,编译的时候,比如Animal an = new Dog(),编译器会将an认为是Animal而不会是Dog,只有在代码运行时,才会知道它是Dog;故使用an调用Dog中没有重写的方法会报错,使用an调用Animal中Dog没有重写的方法时,不会发生多态,会运行Animal的方法
- 向上转型要注意满足多态条件
- 向下强制转型要注意不能转成不同子类(即使是继承同一个父类),否则回报转型错误。
final
-
修饰变量:一旦被赋予初值,就不能被更改。
-
修饰方法:该方法不能被子类重写,但是可以被重载。
-
修饰类:修饰的类不能被继承。
非静态内部类
- 非静态内部类一定要寄存一个外部类对象里。非静态内部类对象单独属于外部类的某个对象。
- 非静态内部类可以直接访问外部类成员,但是外部类不能直接访问非静态内部类成员。
- 非静态内部类不能有静态方法,静态属性,静态初始化块。
- 外部类的静态方法,静态代码块不能访问非静态内部类。
- 成员变量访问要点:
a. 内部类里方法的局部变量:变量名
b. 内部类属性:this.变量名
c. 外部类属性:外部类名.this. 变量名
Map类
1.范型:Map<K,V>,其中K和V不能是基本数据类型,可以是引用类型和包装类。
2.对于HashMap:
a.HashMap:线程不安全,效率高,允许Key或Value为空;
b.HashTable:线程安全,效率低,不允许Key或Value为空。
c.TreeMap在需要排序的Map时,使用TreeMap。
IO流
只有OutputStream输出流(输入流不可以)才能在读入文件对象的时候把不存在的文件自动创建,且前一父类的文件目录若也不存在的情况,则会报错。就是说,必须先保证父路径真实存在。