深入理解Java中四种创建对象的方式
作者:六尺帐篷
链接:https://www.jianshu.com/p/7584b028cbda
调用new语句创建对象 调用对象的clone()方法 运用反射手段创建对象 运用反序列化手段
调用new语句创建对象
// 使用java语言的关键字 new 创建对象,初始化对象数据
MyObject mo = new MyObject() ;
调用对象的clone()方法
MyObject anotherObject = new MyObject();
MyObject object = anotherObject.clone();
1.被克隆的类要实现 Cloneable 接口。
2.被克隆的类要重写 clone()方法。
浅拷贝: 对值类型的成员变量进行值的复制,对引用类型的成员变量只复制引用,不复制引用的对象. 搜索公众号互联网架构师回复“2T”,送你一份惊喜礼包。 深拷贝: 对值类型的成员变量进行值的复制,对引用类型的成员变量也进行引用对象的复制.
原型模式的优点。
原型模式的使用场景。
运用反射手段创建对象
反射的定义
反射机制是在运行时, 对于任意一个类, 都能够知道这个类的所有属性和方法;对于任意一个对象, 都能够调用它的任意一个方法。在 java 中,只要给定类的名字, 那么就可以通过反射机制来获得类的所有信息。 反射机制主要提供了以下功能:在运行时判定任意一个对象所属的类;在运行时创建对象;在运行时判定任意一个类所具有的成员变量和方法;在运行时调用任意一个对象的方法;生成动态代理。
哪里用到反射机制?
反射的实现方式
Class.forName(“类的路径” ); 类名.class 对象名.getClass() 如果是基本类型的包装类, 则可以通过调用包装类的 Type 属性来获得该包装类的 Class 对象, Class clazz = Integer.TYPE;
实现 Java 反射的类
1)Class:它表示正在运行的 Java 应用程序中的类和接口。 2)Field:提供有关类或接口的属性信息, 以及对它的动态访问权限。 3)Constructor:提供关于类的单个构造方法的信息以及对它的访问权限
注意:Class类是Java反射中最重要的一个功能类,所有获取对象的信息(包
括:方法/属性/构造方法/访问权限)都需要它来实现。
反射机制的优缺点
优点:
缺点:
运用反序列化手段
序列化与反序列化
为什么需要序列化与反序列化
对象序列化
java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。只有实现了Serializable和Externalizable接口的类的对象才能被序列化。 java.io.ObjectInputStream代表对象输入流,它的readObject()方法从一个源输入流中读取字节序列,再把它们反序列化为一个对象,并将其返回。
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
/*
* 序列化流:把对象按照流一样的方式存入文本或者在网络中传输; 对象 ---> 流 :ObjectOutputStream
* 反序列化流:把文本文件中的流对象数据或者网络中的流对象数据还原成对象。 流---> 对象 :ObjectInputStream
*/
public class ObjectStreamDemo {
public static void main(String[] args) throws IOException {
// 序列化数据其实就是把对象写到文本文件
//write();
read();
}
private static void read() throws IOException {
// 创建反序列化流对象
ObjectInputStream ois = new ObjectInputStream(new FileInputStream(
"a.txt"));
// 读取,还原对象
try {
Person p = (Person) ois.readObject();
System.out.println(p.toString());
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
ois.close();
}
private static void write() throws IOException {
// 创建序列化流对象
// public ObjectOutputStream(OutputStream out)
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(
"a.txt"));
// 创建对象
Person p = new Person("java", 20);
oos.writeObject(p);
// 释放资源
oos.close();
}
}
import java.io.Serializable;
/*
* NotSerializableException为序列化异常,
* 该类需要实现一个接口:Serializable序列化接口,该接口中并没有任何方法,仅仅作为标识。
* 类似于此的没有方法的接口是标记接口
*
* !!!每一次去修改该类的时候都会生成一个新的序列化标识的值!,需要重新新,重新读,这是基本方法。
* 想办法来固定该类的标识ID,人为设定。这样即使再次修改类的内容,只要ID固定了就可以保证,在读取的时候一直是匹配的。
* 增加 generated serial version ID,在类里面直接点击黄色即可,增加一个变化的ID值
*/
/*
* 当有的成员变量不需要被序列化时:如何解决。
* 方法使用transient关键字声明不需要序列化的成员变量
*/
public class Person implements Serializable{
/**
* serialVersionUID
*/
private static final long serialVersionUID = -9164765814868887767L;
private String name;
private transient int age;
public Person() {
super();
}
public Person(String name, int age) {
super();
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
}
感谢您的阅读,也欢迎您发表关于这篇文章的任何建议,关注我,技术不迷茫!小编到你上高速。
正文结束
1.心态崩了!税前2万4,到手1万4,年终奖扣税方式1月1日起施行~
评论