美文网首页
Java编程思想--第5章 初始化与清理

Java编程思想--第5章 初始化与清理

作者: jchenluo | 来源:发表于2018-08-30 20:42 被阅读0次

    5.1 用构造器确保初始化

    Java中构造器采用与类名相同的名字,首字母必须大写。不接受任何参数的构造器叫做无参构造器,也有有参构造器,可以在初始化对象的时候提供一些参数。

    构造器没有返回值。这与返回值为空(void)有明显不同。对于空返回值,尽管方法本身不会自动返回什么,但是仍可以选择让它返回一些东西。构造器则不会返回任何东西,别无选择。

    Java中,初始化和创建时捆绑在一起的,两者不能分离。

    5.2 方法重载

    5.2.1 区分重载方法

    每个重载方法都必须要有一个独一无二的参数类型列表。包括参数数量、类型、顺序等。

    5.2.2 涉及基本类型的重载

    如果某这个基本类型的重载,使用这个。

    如果传入的数据类型小于方法中声明的形式参数类型,实际数据类型就会被提升。char类型特殊,若找不到,会提升至int型。

    如果传入的数据类型大于方法中声明的形式参数类型,必须通过类型转换的窄化转换,即显式转换,否则编译器会报错。

    无法通过返回值来区分重载方法。

    5.3 默认构造器

    如果你写的类中没有构造器,则编译器会自动帮你创建一个默认构造器(无参构造器),如果已经定义了一个构造器,不管是有参的还是无参的,编译器就不会再创建一个了。

    5.4 this关键字

    假设希望在方法的内部获得对当前对象的引用,可以用this关键字。

    只有当需要明确得指出对当前对象的引用时,才需要使用this。如果在方法内部调用同一个类的另一个方法,就不必使用this,直接调用即可。

    5.4.1 在构造器中调用构造器

    如果想要在一个构造器中调用另一个构造器,以避免重复代码,可以使用this.

    可以用this调用一个构造器,不能够调用两次。

    必须将构造器调用置于最起始处。并且只能在构造器中调用。

    5.4.2 static的含义

    static方法就是没有this的方法,在static方法的内部就不能调用非静态方法。

    static方法最主要的用途:直接用类名调用。

    class Person{

        static A(int i){

                C(i); 

    //静态方法A,这里调用同一个类下的C方法,C是一个普通方法,编译器报错。因为C()等价于this.C(),而this不存在。        }

        void B(int i){

            C(i);

    //这里可以这么写,因为C()等价于this.C()。而普通方法在创建对象时生成,this表示调用B()的对象,故调用成功。        }

        void C(int i){}

    }

    5.5 清理:终结处理和垃圾回收

    假定一个对象并非使用new获得了一块特殊的内存区域,由于垃圾回收器只知道释放那些经由new分配的内存,所以它不知道该如何释放这一块特殊的内存。

    为了应付这种情况,Java允许在类中定义一个名为finalize()的方法。它的工作原理假定是这样的:一旦垃圾回收器准备好释放对象占用的存储空间,将首先调用其finalize()方法,并且在下次回收动作发生时,才真正回收对象占用的内存。

    Java的finalize()和C++析构函数不同,析构函数在调用完成后会自动调用解放对象占用的内存。Java对象并非总是被垃圾回收的。

    5.5.1 finalize()的用途何在

    对象可能不被垃圾回收;垃圾回收不等于析构;垃圾回收只与内存有关。

    使用垃圾回收器的唯一原因是为了回收程序不再使用的内存。

    finalize()的用途就是在使用“本地方法”的情况下,本地方法是一种在java中调用非java代码的方式,一般来讲是c和C++,如C的malloc()函数分配储存空间,只能free()函数来释放空间,这需要将free()函数在finalize()中调用。

    finalize 方法将在垃圾回收器清除对象之前调用。在实际应用中,不要依赖于使用 finalize 方法回收任何短缺的资源, 这是因为很难知道这个方法什么时候才能够调用。

    5.5.2 你必须实施清理

    Java不允许创建局部对象,必须使用new创建对象。在Java中也没有用于释放对象的delete,因为垃圾回收器会帮助你释放存储空间。甚至可以认为,正是因为有垃圾收集的机制,所以Java没有析构函数。而且不能随便的调用finalize。

    5.5.3 终结条件

    System.gc()用于强制进行终结动作。

    5.5.4 垃圾回收器如何工作的

    http://www.cnblogs.com/andy-zcx/p/5522836.html

    5.6 成员初始化

    在Java中,面对局部变量没有被初始化时会得到编译错误的消息。这是因为可能程序猿因为粗心忘记了初始化,如果使用默认值就掩盖了这种错误。

    而对于类的数据成员,Java保证每一个基本类型成员都有初始化值,如果是一个引用类型,就会得到null。

    5.7 构造器初始化

    可以使用构造器来进行初始化。但是无法阻止自动初始化的进行,它将在构造器被调用之前发生。

    举个例子

    class Counter{

        int i;

        Counter(){i=7;}

    }

    这里变量i会先初始化为0,然后在调用构造器后,变成7.

    5.7.1 初始化顺序

    在类的内部,变量定义的先后顺序决定了初始化的顺序,假如变量分布在各处,也是按照从上向下的顺序初始化。

    5.7.2 静态数据的初始化

    无论创建多少个对象,静态数据只占用一份储存区域。static 关键字不能应用于局部变量,即只能作为类的数据成员。

    5.8 数组初始化

    Arrays.toString()方法属于java.util标准类库,将产生一维数组的可打印版本。

    5.9 枚举类型

    枚举类型是Java 5中新增特性的一部分,它是一种特殊的数据类型,之所以特殊是因为它既是一种类(class)类型却又比类类型多了些特殊的约束,但是这些约束的存在也造就了枚举类型的简洁性、安全性以及便捷性。

    public class EnumDemo {

        public static void main(String[] args){

            //直接引用        Day day =Day.MONDAY;

        }

    }//定义枚举类型enum Day {

        MONDAY, TUESDAY, WEDNESDAY,

        THURSDAY, FRIDAY, SATURDAY, SUNDAY

    }

    实际上在使用关键字enum创建枚举类型并编译后,编译器会为我们生成一个相关的类,这个类继承了Java API中的java.lang.Enum类,也就是说通过关键字enum创建枚举类型在编译后事实上也是一个类类型而且该类继承自java.lang.Enum类。

    编译器确实帮助我们生成了一个Day类(注意该类是final类型的,将无法被继承)而且该类继承自java.lang.Enum类,该类是一个抽象类(稍后我们会分析该类中的主要方法),除此之外,编译器还帮助我们生成了7个Day类型的实例对象分别对应枚举中定义的7个日期,这也充分说明了我们前面使用关键字enum定义的Day类型中的每种日期枚举常量也是实实在在的Day实例对象,只不过代表的内容不一样而已。注意编译器还为我们生成了两个静态方法,分别是values()和 valueOf()。

    https://blog.csdn.net/javazejian/article/details/71333103

    相关文章

      网友评论

          本文标题:Java编程思想--第5章 初始化与清理

          本文链接:https://www.haomeiwen.com/subject/ntadwftx.html