- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
在Java语言中,当我们需要拷贝一个Java对象的时候,常见的会有两种方式的拷贝:浅拷贝与深拷贝。
浅拷贝代码演示(最常见的方式):
/**
* 浅拷贝:拷贝的就是目标对象在堆内存中的地址
* 注意:拷贝对象改变,源对象(目标对象)改变
*/
public class SlowCopy {
public static void main(String[] args) {
User user = new User();
user.setUserName("张三");
user.setPassWord("123456");
//浅拷贝
User user1 = user ;
System.out.println(user); //com.sqx.copy.bean.User@1b6d3586
System.out.println(user1); //com.sqx.copy.bean.User@1b6d3586
}
}
深拷贝的对象修改的时候,源对象是不受影响的!
一般常用的深拷贝方式有如下5种
1、构造函数方式
/**
* 构造器实现深拷贝 :我们拷贝对象和源对象是隔离的,互不干扰!
*/
public class DeepCopy {
public static void main(String[] args) {
//深拷贝
User user = new User("张三","123456");
User user1 = new User("李四","654321");
System.out.println(user); //com.sqx.copy.bean.User@1b6d3586
System.out.println(user1); //com.sqx.copy.bean.User@4554617c
}
}
2、重写Clone方法
1、实现Cloneable接口,Cloneable其实就是一个标记接口,只有实现这个接口后,然后在类中重写Object中的clone方法,然后通过类
调用clone方法才能克隆成功,如果不实现这个接口,则会抛出CloneNotSupportedException(克隆不被支持)异常。
public class Student implements Cloneable {
private String userName ;
private String passWord ; // 此处省略set\get方法
@Override
public Student clone() throws CloneNotSupportedException {
return (Student) super.clone();
}
}
2、代码演示深拷贝
/**
* 重写clone方法实现深拷贝
*/
public class DeepCopy01 {
public static void main(String[] args) {
Student student01 = new Student("张三","123456");
Student student02 = null;
try {
student02 = student01.clone(); // 深拷贝对象
} catch (CloneNotSupportedException e) {
e.printStackTrace();
}
System.out.println(student01); //com.sqx.copy.bean.Student@1b6d3586
System.out.println(student02); //com.sqx.copy.bean.Student@4554617c
System.out.println(student01.equals(student02)); // true 标识内容相同,但是仅地址不同(记得重写equlas)
}
}
我们发现拷贝的student02对象和源对象地址已经不同了,但是内容是一致的~
补充
我们的ArrayList 、LinkedList等都实现了Cloneable接口,支持深拷贝
public class ArrayList<E> extends AbstractList<E>
implements List<E>, RandomAccess, Cloneable, java.io.Serializable {
...
}
样例演示:
public class ArrayListCopyTest {
public static void main(String[] args) {
ArrayList<User> list = new ArrayList<>();
User user = new User("张三", "123456");
list.add(user) ;
System.out.println("list: "+list); //源ArrayList对象
ArrayList<User> clone = (ArrayList<User>) list.clone();
System.out.println("clone: "+clone); //经过深拷贝得到的ArrayList对象
System.out.println(list == clone); // false 经过深拷贝,创建的是新的对象
System.out.println(list.get(0) == clone.get(0)); //true 说明拷贝对象和源对象的内容是一样的!
}
}
总结:
实现深拷贝的方式还有:Apache Commons Lang序列化、Gson序列化、jackson序列化等
拿这个: var lists:{ item1:{} ,item2:{} ,item3:{} ,item4:{} } 由于它基本上是空的,我想要一个函数(可能但不一定是 _lodash
我想更改 ng bootstrap 分页组件的样式并在 Angular 6 应用程序中使用 /deep/ 链接。以下代码工作正常,但控制台显示警告,指出该代码已被弃用。 那么,我应该如何更改它以消除警
使用 webcomponents,您可以使用 /deep/ 定位 shadowdom 的内部元素,在我尝试使用事件委托(delegate)之前它工作正常。 一个常规的点击功能将起作用: $('html
在 Swift 中,我试图实现一个单词 Trie,使用文字表示作为一系列嵌套的 NSObject。这是 Trie。 let GEENITRIE:NSObject = [ "i":[
运行 npm update 更新 package.json 中列出的项目;但是,这些项目的依赖关系仍然过时。 明显的解决方法是再次运行 npm update。有时我需要运行它 3 次以上才能使 npm
我创建了 2 级嵌套 linq 查询: var data = (from p in Departments join e in Employees on p.Id equals
首先是代码 #include typedef wchar_t* BSTR; wchar_t hello[] = L"Hello"; class _bstr_t { public: opera
我要编写一个 lisp 程序来生成十六进制数的实际值。我已经编写了一个函数,但似乎出现了 stackoverflow(深度)错误。我想知道是否有人可以指出我的错误或指导我朝着正确的方向前进。 如果没有
我想将每种类型都转换为boolean 或object type CastDeep = { [P in keyof T]: K extends K[] ? K[] : T[P] ex
我刚刚发现自己在写这个: fn init_timestamps(dir: &PathBuf, file_timestamps: &'static HashMap) { match fs::re
我有一个现有的 pybind11::array_t,需要进行复制构造。 pybind11 中是否有一个函数允许我对 array_t 进行深度复制? 我知道我可以创建一个新的 array_t,适当调整大
引用http://www.devx.com/tips/Tip/13291 ,它说我可以使用 memcpy 来复制由 sizeof() 确定的大小,但是,数组不是指向指针吗? 除了遍历数组,如何使用 m
我有多个成员(member),每个成员(member)都有一条记录,其中包含几个备注字段: Member ID Entry A Entry B 1 [memo t
$watchCollection 是否能够忽略对以 $ 开头的属性的更改?使用深度 $watch 时已经存在此行为,因为它依赖于 angular.equals 进行比较。 理想情况下,$watchCo
我有一个带有复杂键的 map - 例如,二维数组: m := make(map[[2][3]int]int) 当我在映射中插入一个新键时,Go 是否会对该键进行深度复制? a := [2][3]int
我需要查询如下所述的三个表。我了解简单的 JOIN,但是这个有点超出我的水平。 courses 有两列 id (PK) 和 courseTitle(示例 id 1,courseTitle 物理) cl
我有一个对象,它是 Realm 的 Object 子类,并且符合 Codable 以便在与 API 对话时与 JSON 相互转换。 如何利用 Codable 协议(protocol)进行深度复制(包括
我是一名优秀的程序员,十分优秀!