Java SE 面向對象編程的3個常用接口
1.Comparable
前言,想要排序Student.有代碼:
import java.util.Arrays; class Student { public int age; public String name; public double score; public Student(int age, String name, double score) { this.age = age; this.name = name; this.score = score; } @Override public String toString() { return "Student{" + "age=" + age + ", name='" + name + '\'' + ", score=" + score + '}'; } } public class TestDemo { public static void main(String[] args) { Student[] students = new Student[3]; students[0] = new Student(12,"niubi",99.9); students[1] = new Student(20,"liuren",18.9); students[2] = new Student(80,"laoren",50.9); System.out.println(Arrays.toString(students)); Arrays.sort(students); System.out.println(Arrays.toString(students)); } }
此代碼運行報錯:
原因: 沒有告訴要如何進行排序,是年齡還是姓名還是分數.沒有告訴比較的規則
解決方式:
如果自定義的數據類型 進行大小比較 一定要實現可以比較的接口
import java.util.Arrays; class Student implements Comparable<Student>{ public int age; public String name; public double score; public Student(int age, String name, double score) { this.age = age; this.name = name; this.score = score; } @Override public String toString() { return "Student{" + "age=" + age + ", name='" + name + '\'' + ", score=" + score + '}'; } //誰調用這個方法 誰就是this @Override public int compareTo(Student o) { //return this.age - o.age;//從小到大 return o.age - this.age;//從大到小 } } public class TestDemo { public static void main(String[] args) { Student[] students = new Student[3]; students[0] = new Student(12,"niubi",99.9); students[1] = new Student(6,"liuren",18.9); students[2] = new Student(80,"laoren",50.9); System.out.println("比較前 "+Arrays.toString(students)); Arrays.sort(students);//默認從小到大排序 System.out.println("比較後 "+Arrays.toString(students)); } }
如果要 分數比較 和 姓名比較
//誰調用這個方法 誰就是this @Override public int compareTo(Student o) { //return this.age - o.age;//從小到大 //return o.age - this.age;//從大到小 return (int) (this.score - o.score);//分數排序 return this.name.compareTo(o.name);//姓名排序 }
缺點: 這個接口對類的侵入性非常強.一旦寫好瞭,不敢輕易改動.
如何降低對類的侵入性呢?
使用Comparator
2.Comparator 比較器
import java.util.Arrays; import java.util.Comparator; class Student1 { public int age; public String name; public double score; public Student1(int age, String name, double score) { this.age = age; this.name = name; this.score = score; } @Override public String toString() { return "Student{" + "age=" + age + ", name='" + name + '\'' + ", score=" + score + '}'; } } class AgeComparator implements Comparator<Student1>{ @Override public int compare(Student1 o1, Student1 o2) { return o1.age - o2.age; } } class ScoreComparator implements Comparator<Student1>{ @Override public int compare(Student1 o1, Student1 o2) { return (int) (o1.score - o2.score); } } class NameComparator implements Comparator<Student1>{ @Override public int compare(Student1 o1, Student1 o2) { return o1.name.compareTo(o2.name); } } public class TestDemo1 { public static void main(String[] args) { Student1[] students1 = new Student1[3]; students1[0] = new Student1(12,"niubi",99.9); students1[1] = new Student1(6,"liuren",18.9); students1[2] = new Student1(80,"laoren",50.9); System.out.println("比較前 "+Arrays.toString(students1)); AgeComparator ageComparator = new AgeComparator(); Arrays.sort(students1,ageComparator); System.out.println("比較後(按年齡) "+Arrays.toString(students1)); ScoreComparator scoreComparator = new ScoreComparator(); Arrays.sort(students1,scoreComparator); System.out.println("比較後(按姓名) "+Arrays.toString(students1)); NameComparator nameComparator = new NameComparator(); Arrays.sort(students1,nameComparator); System.out.println("比較後(按分數) "+Arrays.toString(students1)); } }
運行結果:
優點:對類的侵入性非常弱.
3.Cloneable
面試問題:
你知道Cloneable接口嗎?為啥這個接口是一個空接口?有啥作用?
空接口 -> 標志接口 -> 代表當前這個類是可以被克隆的.
class Person implements Cloneable{ public int age ; public void eat(){ System.out.println("吃!"); } @Override public String toString() { return "Person{" + "age=" + age + '}'; } @Override protected Object clone() throws CloneNotSupportedException { return super.clone(); } } public class TestDemo2 { public static void main(String[] args) throws CloneNotSupportedException { Person person = new Person(); person.age = 99; Person person2 = (Person) person.clone(); System.out.println(person.age); System.out.println(person2.age); System.out.println("=========="); person2.age = 199; System.out.println(person.age); System.out.println(person2.age); } }
運行結果:
註意事項:
- 1.引用的對象要想被克隆,必須實現Cloneable接口.
- 2.必須重寫克隆方法,並且聲明異常.
到此這篇關於 Java SE 面向對象編程的3個常用接口的文章就介紹到這瞭,更多相關 Java SE 面向對象編程接口內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Java入門基礎之抽象類與接口
- Java設計模式之java策略模式詳解
- Java語法之 Java 的多態、抽象類和接口
- 基於Arrays.sort()和lambda表達式
- Java抽象類和接口使用梳理