thinking in java学习记录(五) 初始化与清理

用构造器确保初始化
构造器采用与类相同的名称,所以每个方法首字母小写不适用于构造器,且没有返回值
在java中,“初始化”和“创建”是捆绑在一起的,两者无法分离

方法重载
通过独一无二的参数列表来区分重载的方法,甚至参数列表的顺序也能区分不同的重载方法,但是根据方法的返回值来区分不同的重载方法是不行的

默认构造器
如果已经定义了一个构造器(无论是否带参数),那么编译器就不会帮你创建默认构造器

this关键字
其实当我们调用方法时,例如f.x();编译器会把“所操作对象的引用”当做第一个参数传给方法,于是上诉方法就变成了F.x(f)
而static方法就是没有this的方法,在static方法中不能调用非静态方法,而且可以在没有创建任何对象的前提下,仅仅通过类本身来调用static方法

清理:终结处理和垃圾回收
1.对象可能不被垃圾回收(垃圾回收本身也有开销,所以有时为了避免,可以不回收)
2.垃圾回收不等于析构
3.垃圾回收只与内存有关

垃圾回收是先调用finalize()方法,下次再进行垃圾回收时,再调用内存回收(绝对不能直接调用finalize())

finalize是用于释放以除了创建对象方式以外的方法申请了的内存

java垃圾回收器使用停止-复制标记-清扫

停止-复制意味着先暂停程序的运行,然后将所有存活的对象从当前堆复制到另一个堆,没有被复制的全是垃圾。

标记-清扫是在没有新垃圾产生时使用的策略。每当他找到一个存活的对象,便给它一个标记,当所有标记工作完成时,清理工作才会开始。

成员初始化

成员变量会自动初始化,局部和静态变量都不会自动初始化

构造器初始化

在类的内部,变量定义的先后顺序决定了初始化的顺序,无论变量定义在方法定义之间,他们仍然会在任何方法调用之前得到初始化,包括构造器
static关键字不能作用于局部变量,所以它只能作用于类

静态初始化只有在必要的时候才会进行,此后静态对象不会再次被初始化
总结一下对象创建的过程(假设有个Dog类):
1.即使没有显示的使用static关键字,构造器其实也是静态方法,因此在首次创建类型Dog的对象时,或者Dog类的静态方法/域首次被访问时,java解释器必须查找类路径,以定位Dog.class文件
2.然后载入Dog.class文件,有关静态初始化的所有动作都会执行,因此静态初始化只会在Class对象首次加载时执行
3.当使用new Dog()创建对象时,首先将在堆上为Dog对象分配足够的存储空间
4.这块存储空间首先会被清零,这就自动地将Dog对象中的所有成员对象初始化为默认值,而引用就会被设为null
5.执行所有出现在字段定义处的初始化动作
6.执行构造器

数组初始化

编译器不允许我们制定数组的大小,因为我们拥有的只是对数组的一个引用(你已经为该引用分配了足够的内存空间),而且也没有为数组对象本身分配任何空间。

可变参数列表(Object… arg)

因为所有的类都直接或间接继承了Object对象,可变参数列表即Object数组,且要用for-each来循环(数组可转换为可变参数列表,但不可逆)。可变参数列表并不依赖包装类型,可以直接使用基本类型

枚举类型

enum有个特别实用的特性,就是用在switch()语句内。

enum.values()可以将枚举类型转换为数组

发布了28 篇原创文章 · 获赞 1 · 访问量 649

猜你喜欢

转载自blog.csdn.net/c630843901/article/details/102329658