构造器:
1、当类中没有声明构造器时, 编译器会自动生成一个默认构造器。但是如果类中定义了一个带参构造器时,为了确保正确性,编译器不会自动生成默认构造器,此时应当显式定义默认构造器。当父类中有带参构造器而没有默认构造器时,在子类的构造函数中如果想要调用父类的构造器,则需要使用关键字super
class A{
A(int i){
System.println("A");
}
}
class B extends A{
B(int i){
super(i);
System.out.println("B");
public static void main(string[] args){
B b = new B(1);
}
}
//output:
A
B
2、构造器中需要对空白final进行初始化,这保证了空白final在使用前总是被初始化。初始化时既可以使用默认构造器,又可以使用带参构造器,并且可以使用参数初始化空白final
3、构造器是隐式static方法
4、复杂构造器顺序:1)分配空间,并初始化为全0 2)调用基类构造器 3)按声明顺序调用成员初始化方法 4)调用导出类构造器的主体(也就是本类的构造器)
5、public全部可见,protected子类可见,default(也就是构造器前面不加其他三个修饰)包内可见,private本类可见。因此如果想在包外实例化一个类,则需要将其构造器声明为public型
6、当声明一个自定义类的数组时,数组的每个元素都需要new,否则会抛出空指针错误
class A{
A();
}
class B{
public static void main(String[] args){
A arrayA = new A[10];
for(A a: arrayA){
a = new A();
}
}
}
重载:
@Override:在覆写方法前增加该关键字,可以避免把覆写写成重载
静态方法:
static关键字修饰的方法为静态方法,静态方法无需实例化即可调用。类的静态方法不属于类的对象,而属于类本身,在该类首次使用的时候加载到系统的方法区中,一般可以使用类名直接调用类的静态方法,而不需要实例化对象。由于静态方法并不属于对象,因此在静态方法中无法操作类的普通成员变量,只能操作类的静态成员变量。(因为普通成员变量依附于类的对象存在,而类的静态方法并不属于类对象,在类对象被实例化之前静态方法就已经存在,故在静态方法中操作普通成员变量,相当于在无对象的情况下对其中的成员变量进行操作,这是无意义的,同时也不符合面向对象的思想。)
静态方法中,不能使用this。在一个项目中,需要加载配置文件,配置文件只需要加载一次,但是配置文件加载接口用到了this,因此不能直接static中写,想到了一个曲线救国的方案是,配置文件对应的变量设置为static变量,初始化为null,在构造函数中使用if-else,如果该变量为null则进行加载,否则不进行加载
多态:
只有普通的方法调用是多态的,对于某个域的直接访问不是多态的。当一个子类和父类都含有一个属性值时,子类向上转型产生的父类对于该值的访问是对于父类值的访问,实际上编译器为两者的属性值都分配了空间。在子类中对父类相同属性值访问时要使用super。
静态方法也不是多态的
Final:
1、final修饰的参数在方法中不能被修改
2、private是隐式final
Arrays:
1、Arrays.<class>asList();
2、当使用for循环索引进行数组中某些元素删除时,删除以后由于当前索引指向位置变成了原来的下一个元素,因此应当将索引减一,以避免部分元素被跳过
String:
1、字符串比较操作,一定要用String类的equals方法
Java没有引用传递,只有值传递
13万+

被折叠的 条评论
为什么被折叠?



