Arrays.sort(a) 自定义排序,(需实现接口:Comparable)

package com.hd;

import java.util.Arrays;

class Person implements Comparable{
int id ;
int score ;
public Person(int id,int score){
this.id = id;
this.score = score ;
}
@Override
public String toString(){
return "id:"+id+" score:"+score ;
} @Override
public int compareTo(Object o) {
Person p = (Person)o ;
int temp ;
     temp= this.score > p.score ? 1:this.score==p.score?0:-1;
if(temp==0)
return this.id >p.id? 1:-1;
return temp ;
} }
public class Main
{
public static void main(String args[])
{
Person p[]={new Person(9,80),
            new Person(8,90),
            new Person(8,70)};
Arrays.sort(p);
System.out.println(Arrays.toString(p)); }
}
//---------[id:8 score:70, id:9 score:80, id:8 score:90]

 1. sort():

Arrays.sort(Object[] a) --> Arrays.mergeSort()
--->((Comparable) dest[j-1]).compareTo(dest[j])>0
Comparable转换是为了调用compareTo()
      虽不在编译的时候报错,但如果没实现的话,
      运行时会:ClassCastException*,


 2. toString():

Arrays.toString(Object[] a)
          let the string of array append :[ .... ]
---->include:String.valueOf(Object a)
----->include:Object.toString()
--< self implement
        (overwrite the method of super class,Object)
          impelment person.toString();


 3. 导包:

     为什么在Arrays中可以未经导包,自由出现Comparable接口,
java.lang包是核心类库,它包含了运行java程序必不可少的系统类,
     系统自动为程序引入java.lang包中的类
    (如:System Math String)因此不需要再import引入;

-----------------------------------------------
   4.继承:

  (1)构造:
   子类的构造方法在创建一个子类的对象时,总是先调用父类的某个构造方法,
     如无指出,则是无参数的那个;
   因此,在子类创建对象时,不仅子类中声明的成员变量被分配了内存,
     而且父类中的成员变量也被分配了内存,
   看似浪费 ,但是注意,子类中还有一部分中的方法时从父类继承的
     这部分方法却可以操作这部分未继承的private成员;

 (2)重写类型
    jdk1.5后,允许重写方法的类型可以是父类方法的子类型,即不必完全一致,
     也就是说如果父类方法中的类型是类,则重写方法中可以是子类,

 (3)上转型
    对象的上转型对象:(前提是 B extends A )
    A a ;
    a = new B() ;
    但是上转型对象会失去原对象的一些属性,
    1,。不能操作子类新增的属性;
    2. 继承的或重写的,
    因为在Object 中没有实现,


 5.接口:
    不能自己new对象,
    只能得到所实现的类的引用,然后使用所实现的方法,接口回调;


Arrays.sort(a) 自定义排序的更多相关文章

  1. [LeetCode] Custom Sort String 自定义排序的字符串

    S and T are strings composed of lowercase letters. In S, no letter occurs more than once. S was sort ...

  2. [leetcode]791. Custom Sort String自定义排序字符串

    S and T are strings composed of lowercase letters. In S, no letter occurs more than once. S was sort ...

  3. 5.4 集合的排序(Java学习笔记)(Collections.sort(),及Arrays.sort()底层分析)

    1.Comparable接口 这个接口顾名思义就是用于排序的,如果要对某些对象进行排序,那么该对象所在的类必须实现 Comparabld接口.Comparable接口只有一个方法CompareTo() ...

  4. C# - List.Sort()自定义排序方法

    本文通过示例介绍了C#中典型容器List.Sort()的自定义排序方法,进而引出了C#中自定义排序的核心接口及方法 项目地址:自定义Sort方法 - SouthBegonia's Github Lis ...

  5. Java8 Collections.sort()及Arrays.sort()中Lambda表达式及增强版Comparator的使用

    摘要:本文主要介绍Java8 中Arrays.sort()及Collections.sort()中Lambda表达式及增强版Comparator的使用. 不废话直接上代码 import com.goo ...

  6. Arrays.sort解析

    Arrays.sort()解读 在学习了排序算法之后, 再来看看 Java 源码中的, Arrays.sort() 方法对于排序的实现. 都是对基本数据类型的排序实现, 下面来看看这段代码: Arra ...

  7. 集合(一)-Java中Arrays.sort()自定义数组的升序和降序排序

    默认升序 package peng; import java.util.Arrays;  public class Testexample { public static void main(Stri ...

  8. java.util.Arrays.sort两种方式的排序(及文件读写练习)

    import java.io.*; import java.util.*; public class SortTest{ public static void main(String args[]) ...

  9. 31、Arrays数组排序(续)——自定义排序

    自定义的类要按照一定的方式进行排序,比如一个Person类要按照年龄进行从小到大排序,比如一个Student类要按照成绩进行由高到低排序. 这里我们采用两种方式,一种是使用Comparable接口:让 ...

随机推荐

  1. 解决v-for产生的警告的办法

    当 Vue.js 用 v-for 正在更新已渲染过的元素列表时,它默认用 “就地复用” 策略.如果数据项的顺序被改变,Vue将不是移动 DOM 元素来匹配数据项的顺序, 而是简单复用此处每个元素,并且 ...

  2. javaweb学习总结(十四)——JSP原理(转)

    一.什么是JSP? JSP全称是Java Server Pages,它和servle技术一样,都是SUN公司定义的一种用于开发动态web资源的技术. JSP这门技术的最大的特点在于,写jsp就像在写h ...

  3. 标准C程序设计七---100

    Linux应用             编程深入            语言编程 标准C程序设计七---经典C11程序设计    以下内容为阅读:    <标准C程序设计>(第7版) 作者 ...

  4. 标准C程序设计七---76

    Linux应用             编程深入            语言编程 标准C程序设计七---经典C11程序设计    以下内容为阅读:    <标准C程序设计>(第7版) 作者 ...

  5. Scrapy学习-11-Selector对象使用

    Selector使用 使用背景 我需要使用类似spider项目中,response使用的xpath和css获取页面指定数据,但因为爬取页面较小我们不想创建一个spider项目时,就可以使用scrapy ...

  6. html css的简单学习(三)

    html css的简单学习(三) 前端开发工具:Dreamweaver.Hbuilder.WebStorm.Sublime.PhpStorm...=========================== ...

  7. BZOJ 4326 NOIP2015 运输计划(二分答案 + 树上差分思想)

    题目链接  BZOJ4326 这个程序在洛谷上TLE了……惨遭卡常 在NOIP赛场上估计只能拿到95分吧= = 把边权转化成点权 首先求出每一条路径的长度 考虑二分答案,$check(now)$ 对于 ...

  8. [转]IIS7.5优化--提高线程数来适应高并发

    根据压测结果做出的修改历史: 第一步:只针对maxWorkerThreads.maxIoThreads和minWorkerThreads做了修改<processModel autoConfig= ...

  9. nginx实现反向代理和负载均衡

    利用nginx做反向代理和负载均衡是减轻服务器压力的有效方式.nginx代理服务器接收多个客户端请求, 根据配置的参数均衡到每个tomcat服务器上,tomcat处理请求,返回响应结果给nginx,n ...

  10. IntelliJ IDEA 常用快捷键总结

    个人使用频率的高低排序: Alt+enter               代码提示 Alt+7                查看类的方法 Alt+insert        生成get和set方法 ...