java内部类
java类汇总不仅可以定义变量和方法,还可以定义类,这种类就叫作内部类。根据定义的方式不同,可以分为静态内部类,成员内部类,局部内部类,匿名内部类四种。
静态内部类
(1)静态内部类可以访问外部类所有静态变量和方法,即使private也可以。
(2)静态内部类和一般类一致,可以定义静态变量、方法和构造方法。
(3)其他类使用静态内部类需要使用“外部类.静态内部类”方式,如下所示:Outer.Inner inner = new Out.Inner(); inner.print();
(4)Java集合类HashMap内部就有一个静态内部类Entry。Entry是HashMap存放元素的抽象,HashMap内部维护Entry数组用来存放元素,但是Entry对使用者是透明的。像这种和外部类关系密切,且不依赖外部类实例的,都可以使用静态内部类。
成员内部类
定义在类内部的非静态类,就是成员内部类。成员内部类不能定义静态方法和变量(final修饰的除外)。这是因为成员内部类是非静态的,类初始化的时候先初始化静态成员,如果允许成员内部类定义静态变量,那么成员内部类的静态变量初始化顺序则有歧义了。
局部内部类(定义在方法中的类)
定义在方法中的类,就是局部类。如果一个类只在某个方法中使用,可以考虑使用局部类。
匿名内部类(要继承一个父类或者实现一个接口、直接使用new来生成一个对象的引用)
匿名内部类要求我们必须要继承一个父类或者实现一个接口,当然也仅能继承一个父类或者实现一个接口。同时它也没有class关键字,这是因为匿名类是直接使用new来生成一个对象的引用。
Java泛型
泛型提供了编译时类型安全机制,该机制允许程序员在编译时检测到非法的类型。泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。
Java序列化(创建可复用的Java对象)
保存(持久化)对象及其状态到内存或者磁盘
Java平台允许我们在内存中创建可复用的Java对象,但在一般情况下,只有当JVM运行时处于运行状态时,这些独享才可能存在,即这些对选哪个的生命周期不会比JVM的生命周期长。但在现实应用中,就有可能要求在JVM停止运行之后能够保存(持久化)指定的对象,并在将来重新读取被保存的对象。
java对象的序列化可以帮我们实现该功能。序列化的对象以字节数组保存,静态成员不保存。
使用Java对象序列化,在保存对象时,会把其状态保存为一组字节。在未来,再讲这些字节组装成独享。必须注意的是,对象序列化保存的是对象的状态,也就是它的成员变量。由此可知,对象序列化不会关注类中的静态变量。
序列化用户远程对象传输
除了在持久化对象时会用到对象序列化之外,当使用RMI(远程方法调用),或者在网络中传递对象时,都会用到对象序列化。Java序列化API为处理对象序列化提供了一个标准机制。
Serializable实现序列化
在java中,只要一个类实现了java.io.Serializable接口,那么它就可以被序列化。
ObjectOutputStream和ObjectInputStream对对象进行序列化和反序列化。
在类中增加writeObject和readObject自定义序列化策略。
序列化ID
虚拟机是否允许反序列化,不仅取决于类路径和功能代码是否一致,一个非常重要的点是两个类的序列化ID是否一致(就是private static final long serialVersionUID)
要想将父类对象也进行序列化,就需要让父类也实现Serializable接口。
Transient关键字阻止该变量被序列化到文件中
(1)在变量声明前加上Transient关键字,可以阻止该变量被序列化到文件中,再被反序列化后,transient变量的值被设为初始值,如int是0,对象型的是null。
(2)服务器端给客户端发送序列化对象数据,对象中有一些数据是敏感的,比如密码字符串等,希望对该密码字段在序列化时,进行加密,而客户端如果拥有解密的密钥,只有在客户端进行反序列化是,才可以对密码进行读取,这样可以再一定程度保证序列化对象的数据安全。
JAVA复制
将一个对象的引用复制给另一个对象,一共三种方式。第一种方式是直接赋值,第二种方式是浅拷贝,第三种方式是深拷贝。
(1)直接赋值复制
直接赋值。在java中,A a1 = a2,我们需要理解的是这实际上复制的是引用,也就是说a1 和 a2实际上指向的是同一个对象。因此,当a1变化时,a2里面的成员变量也会跟着变化。
(2)浅复制(复制引用但不复制引用的对象)
创建一个新对象,然后将当前对象的非静态字段复制到该对象,如果字段是值类型的,那么对该字段执行复制,如果该字段是引用类型的,则复制引用但不复制引用的对象。
(3)深拷贝(复制对象和其引用对象)
深拷贝不仅复制对象本身,而且复制对象包含的引用指向的所有对象。
Collection里面有什么子类
List:
(1)可以允许重复的元素
(2)可以插入多个null
(3)是一个有序容器,保持了每个元素的插入顺序,输出顺序就是插入顺序。
(4)常用的实现类有ArrayList、LinkdedList和Vector。ArrayList最流行,因为可以通过索引随意访问,而LinkedList则对于经常需要从List中添加或者删除元素的场合更加合适。
Set:
(1)不允许重复对象
(2)无序容器,无法保证每个元素的存储顺序,TreeSet通过Comparable或者Comparator维护了一个排序顺序。
(3)只允许一个null元素
(4)Set 接口最流行的几个实现类是 HashSet、LinkedHashSet 以及 TreeSet。最
流行的是基于 HashMap 实现的 HashSet;TreeSet 还实现了 SortedSet 接口,因此 TreeSet 是一个根据其 compare() 和 compareTo() 的定义进行排序的有序容器。