一.比较器Comparable和Comparator

  上一篇博客介绍了工具类Arrays工具类 。我们可以对基本类型的数组调用Arrays.sort()函数来进行数组的排序。排序操作在日常开发中经常要使用到。那么String类和自定义类能不能使用Arrays.sort()来进行排序呢。下面我们来试试,如下:

  Java代码

publicclassMystring {

publicstaticvoidmain(String[] args) {

String []a={"早上","中午","下午","傍晚","晚上"};

Person[] b={ newPerson("小白",15),newPerson("小黑",19),

newPerson("小红",14),newPerson("小紫",20)};

Arrays.sort(a);

for(inti=0;i<a.length;i++)

System.out.print(a[i]);

System.out.print("\r\n");

Arrays.sort(b);

for(inti=0;i<b.length;i++)

System.out.println(b[i]);

}

}

//自定义类

classPerson {

publicString name;

publicintage;

publicPerson(String name,intage) {

this.name=name;

this.age=age;

}

}

  程序运行结果:

  我们发现String可以调用Arrays.sort()函数,而我们自定义的Person类报错,看错误的关键字Comparable

  打开String源码

  由此引入比较器Comparable,我们下面利用Comparable接口来实现Person使用Arrays.sort()按年龄排序递增排序。

Comparable接口能够对实现它的类的对象进行排序,主要使用compareTo函数来实现排序。compareTo函数返回int类型,分别返回-1,0,1对应小于,等于,大于。

  把代码改为:

  Java代码

publicclassMystring {

publicstaticvoidmain(String[] args) {

String []a={"早上","中午","下午","傍晚","晚上"};

Person[] b={ newPerson("小白",15),newPerson("小黑",19),

newPerson("小红",14),newPerson("小紫",20)};

Arrays.sort(a);

for(inti=0;i<a.length;i++)

System.out.print(a[i]);

System.out.print("\r\n");

Arrays.sort(b);

for(inti=0;i<b.length;i++)

System.out.println(b[i]);

}

}

//自定义类

classPerson implementsComparable<Person>{

publicString name;

publicintage;

publicPerson(String name,intage) {

this.name=name;

this.age=age;

}

//比较器的比较函数

/**

* 如果当前对象小于比较对象,返回-1

* 如果当前对象等于比较对象,返回0

* 如果当前对象大于比较对象,返回1

*/

@Override

publicintcompareTo(Person o) {

//对象为空,抛出空指针异常

if(o==null)

thrownewNullPointerException();

if(this.age<o.age)

return-1;

if(this.age>o.age)

return1;

return0;

}

//重写toString方法

@Override

publicString toString() {

return"Person [name="+ name + ", age="+ age + "]";

}

}

  运行结果:

  为自定义的Person实现比较器Comparable接口,即可调用Arrays.sort()进行排序。

  另外还有另一种实现方法,实现Comparator接口。

  Java代码

publicclassMystring {

publicstaticvoidmain(String[] args) {

String []a={"早上","中午","下午","傍晚","晚上"};

Person[] b={ newPerson("小白",15),newPerson("小黑",19),

newPerson("小红",14),newPerson("小紫",20)};

Arrays.sort(a);

for(inti=0;i<a.length;i++)

System.out.print(a[i]);

System.out.print("\r\n");

Arrays.sort(b,newPersonComparator());

for(inti=0;i<b.length;i++)

System.out.println(b[i]);

}

}

//自定义类

classPerson {

publicString name;

publicintage;

publicPerson(String name,intage) {

this.name=name;

this.age=age;

}

@Override

publicString toString() {

return"Person [name="+ name + ", age="+ age + "]";

}

}

classPersonComparator implementsComparator<Person>{

//比较器的比较函数

/**

* 如果当前对象小于比较对象,返回-1

* 如果当前对象等于比较对象,返回0

* 如果当前对象大于比较对象,返回1

*/

@Override

publicintcompare(Person o1, Person o2) {

//对象为空,抛出空指针异常

if(o1==null||o2==null)

thrownewNullPointerException();

if(o1.age<o2.age)

return-1;

if(o1.age>o2.age)

return1;

return0;

}

}

二.对象的克隆Clone

  将一个对象复制一份,称作对象的克隆技术。克隆对象分为两步。

  1.实现Cloneable标记接口

  Cloneable是一个标记接口,此接口没有定义任何方法。只是作为一个标记给虚拟机。

  2.重写Object的clone方法

  Java代码

//自定义类person实现Cloneable接口

classPerson implementsCloneable {

publicString name;

publicintage;

publicPerson(String name,intage) {

this.name=name;

this.age=age;

}

//重写Object的clone方法

@Override

protectedObject clone() throwsCloneNotSupportedException

{

returnsuper.clone();

}

}

  克隆的调用:

  Java代码

publicstaticvoidmain(String[] args) {

Person temp=newPerson("王尼玛",18);

try{

Person ok=(Person)temp.clone();//把Object类转化为Person、

System.out.println(ok.name);//输出王尼玛

} catch(CloneNotSupportedException e) {

e.printStackTrace();

}

}

  这样既可以完成对一个对象的克隆,当我们要创建一系列类似的对象时,可以考虑使用克隆技术可以得到更好的性能,比你new创建好一些。

技术分享:凯哥学堂

java对象比较器和克隆的更多相关文章

  1. Java对象比较器对泛型List进行排序-Demo

    针对形如:字段1 字段2 字段3 字段n 1 hello 26 7891 world 89 5562 what 55 4562 the 85 452 fuck 55 995 haha 98 455 以 ...

  2. JAVA对象的深度克隆

    有时候,我们需要把对象A的所有值复制给对象B(B = A),但是这样用等号给赋值你会发现,当B中的某个对象值改变时,同时也会修改到A中相应对象的值! 也许你会说,用clone()不就行了?!你的想法只 ...

  3. JAVA笔记10__Math类、Random类、Arrays类/日期操作类/对象比较器/对象的克隆/二叉树

    /** * Math类.Random类.Arrays类:具体查JAVA手册...... */ public class Main { public static void main(String[] ...

  4. Java对象克隆(Clone)及Cloneable接口、Serializable接口的深入探讨

    Java对象克隆(Clone)及Cloneable接口.Serializable接口的深入探讨 Part I 没啥好说的,直接开始Part II吧. Part II 谈到了对象的克隆,就不得不说为什么 ...

  5. (转)Java对象克隆(Clone)及Cloneable接口、Serializable接口的深入探讨

    原文地址:http://blog.csdn.net/kenthong/article/details/5758884 Part I 没啥好说的,直接开始Part II吧. Part II 谈到了对象的 ...

  6. 【JAVA零基础入门系列】Day14 Java对象的克隆

    今天要介绍一个概念,对象的克隆.本篇有一定难度,请先做好心理准备.看不懂的话可以多看两遍,还是不懂的话,可以在下方留言,我会看情况进行修改和补充. 克隆,自然就是将对象重新复制一份,那为什么要用克隆呢 ...

  7. JAVA对象克隆可能会出现的问题

    首先,区分一下拷贝和克隆: 拷贝:当拷贝一个变量时,原始变量与拷贝变量引用的是同一个对象.当改变一个变量所引用的对象,则会对另一个变量造成影响. 克隆:当克隆一个对象时,是重新的创建了和该对象内容相同 ...

  8. Java对象的克隆和深浅问题

    Java实现克隆的方式 Java实现克隆的方式有如下两种, 推荐采用实现Cloneable接口的方式 实现Cloneable接口, 重写clone方法, 调用父类的clone方法 还有另一种方法, 不 ...

  9. Java对象和集合的拷贝/克隆/复制

    昨天同事遇到了一个奇怪的问题,他需要将一个JavaBean拷贝一份,然后对新创建的Bean进行操作.但是他对新的Bean操作后,会影响旧的Bean的值.当听到这个问题的时候,我第一反应就是他的拷贝方法 ...

随机推荐

  1. poj 1007 DNA Sorting 解题报告

    题目链接:http://poj.org/problem?id=1007 本题属于字符串排序问题.思路很简单,把每行的字符串和该行字符串统计出的字母逆序的总和看成一个结构体.最后把全部行按照这个总和从小 ...

  2. BST树

    http://www.cnblogs.com/bizhu/archive/2012/08/19/2646328.html 4. 二叉查找树(BST) Technorati 标记: 二叉查找树,BST, ...

  3. svn update 每更新一项就输出一行信息,使用首字符来报告执行的动作 这些字符的含义是:

    A 已添加 D 已删除 U 已更新 C 合并冲突 G 合并成功 例子: [root@ok 资料库]# svn ci -m "" Sending 资料库/简历 Transmittin ...

  4. Andorid中的HAL

    参考文章: http://blog.csdn.net/luoshengyang/article/details/6567257

  5. 在windows下用toolbox玩会docker

    哈哈哈.

  6. Mac OS X 上的安装Lisp开发环境

    到网站:https://common-lisp.net/project/lispbox/ 下载lispbox 解压下载下来的包,找到Emacs 测试: 我们也可以使用homebrew来安装lisp的解 ...

  7. android 项目中规范使用SharedPreferences

    一.SharedPreferences是什么来的? SharedPreferences是Android四种数据存储技术中的一种(SharedPreferences.SQLite.Content Pro ...

  8. hud 1785 畅通工程

    #include<iostream> #include<stdio.h> #include<algorithm> #include<math.h> us ...

  9. LianLianKan[HDU4272]

    LianLianKan Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  10. BZOJ2459 : [BeiJing2011]神秘好人

    线段树每个节点维护d[4][4]表示四个顶点之间的最短路,合并时用Floyed合并,查询时分三段然后合并. #include<cstdio> #define N 100010 struct ...