那些年我们掉过的java的坑(一)
1.下面都是对的,public和static没有先后关系,main可以是final
public static void main(String[] args)
static public void main(String[] args)
public static final void main(String[] args)
2.一个.java文件中可以有很多个类,每个类下都可以有main函数,但是只有类名和文件名字一样的相同并且使用public修饰的类中的main函数才会被执行。
1.Java保存的文件名必须与类名一致;
2.如果文件中只有一个类,文件名必须与类名一致;
3.一个Java文件中只能有一个public类;
4.如果文件中不止一个类,文件名必须与public类名一致;
5.如果文件中不止一个类,而且没有public类,文件名可与任一类名一致。
3.静态代码块随类的加载而加载,所以无关前后顺序,都先于main执行
public class Test_1 {
static {
System.out.println("第一执行");
}
public static void main(String[] args) {
System.out.println("第三执行");
}
static {
System.out.println("第二执行");
}
}
4.java程序初始化顺序,非静态代码块每一次new都会执行一次
加载类时:父类静态变量>父类静态代码块>子类静态变量>子类静态代码块
新建对象:父类非静态变量>父类非静态代码块>父类构造函数>子类非静态变量>子类非静态代码块>子类构造函数
5.成员变量的作用域
作用域和可见性 | 当前类 | 同一包下 | 子类 | 其他包下 |
---|---|---|---|---|
public | √ | √ | √ | √ |
protected | √ | √ | √ | |
default | √ | √ | ||
private | √ |
6.当一个.java文件中有几个类时候,编译会为每一个class生成一个.class文件
7.成员方法可以和构造函数同名,虽然会有警告
public class Test_1 {
public Test_1()
{
System.out.println("这是构造方法");
}
public void Test_1()
{
System.out.println("这是成员方法");
}
public static void main(String[] args) {
Test_1 test = new Test_1();
test.Test_1();
}
}
8.当为父类写了构造方法(constructor)后,系统将不会默认创建无参构造方法。那么子类就也不能调用父类没有的构造方法。子类每个构造方法第一句代码都必须是super(),这意思是请求调用父类的构造方法,因为每个对象在构造成功前,都必须先构造其父亲,父亲成功造了,才能有儿子。
9.没有任何方法的接口存在的意义,可以用来做标记。可以使用instanceof来进行判断某个类是否有这个标记。java中存在的标识接口有Cloneable和Serializable。
interface Rubbish{};
class Something implements Rubbish{
public String toString() {
return "Something";
}
}
public class Test_1 {
public static void main(String[] args) {
Something st = new Something();
if(st instanceof Rubbish) {
System.out.println(st);
}
}
}
10.java中的浅复制和深复制,浅复制没有复制成员变量中的引用类型,深复制复制成员变量中的引用类型。
1.在派生类中实现Cloneable接口
2.在派生类中覆盖基类的clone()方法,并声明为public
3.在派生类的clone()方法中,调用super.clone()
4.(深复制多这一步)将来复制后的对象的引用类型成员进行clone()
class User implements Cloneable {
private String name;
private Date birth;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Date getBirth() {
return birth;
}
public void setBirth(Date birth) {
this.birth = birth;
}
public Object clone() throws CloneNotSupportedException {
User o = null;
// Object中的clone()识别出你要复制的是哪一个对象
o = (User) super.clone();
// 深复制
o.birth = (Date) this.getBirth().clone();
return (Object)o;
}
}