Comparable,Comparator,Cloneable接口以及深浅拷贝

大家知道对于数组的 排序可以使用 Array.sort()方法 ,但是如果数组中的元素是通过自定义的类创建的对象呢,还能用这个方法排序吗?我们看以下代码。

 

这段代码是对students数组进行排序,但是结果会报出类型转换异常,如下:

 那想要实现对students数组的排序就要让Student实现Comparable接口,并重写接口中的compareTo方法(指定按哪一个字段比较,并返回比较结果)。

Comparable接口中只有一个方法

实现Comparable接口,并重写了compareTo方法:

 

排序结果:

下面我们看一下这个排序算法底层是如何实现的:

 

分析上段代码:大概是把数组元素强转为Comparable类型然后调用了接口中的compareTo方法,这时候因为数组元素是Student类型,而Student类中重写了compareTo方法,所以发生动态绑定,调用的是Student类中compareTo方法。类似于c语言中的qsort函数。

Comparator接口的使用:

按年龄排序:

 按姓名排序:

Cloneable接口:对一个对象进行克隆 (需要实现Cloneable接口,并且重写Object类中的clone方法)

这里可以看到这个接口里并没有任何方法,所以他是一个空接口又叫标记接口,代表该类创建的对象是可以被克隆的

 

案例1:

 这里通过修改age不难发现,person1和person2是两个对象

案例2:对象中又有一个对象

 

 以上结果可以看出person1和person2中的money引用的是同一个对象,也就是说clone()方法只是并没有把person对象中的money对象也克隆一份(这其实就是浅拷贝)

        下面从代码层次实现深拷贝:

 

我们在重写的clone()方法中将克隆出的person对象的money引用了另一个克隆出的money对象,这样其实就是从代码层面实现了深拷贝

 浅拷贝:

 深拷贝:

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值