那些年我们掉过的java的坑(一)

那些年我们掉过的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;
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值