日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

JAVA复习5(TreeSet)

發布時間:2023/12/19 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JAVA复习5(TreeSet) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Set 接口

?

特點: 最大的特點 就是集合中的元素 不可重復? 其也是Collection接口的子接口 , Set本身也是一個接口,同樣不能直接使用,需要實例化該接口的實現類 Set接口下面的實現類:

常用

1 TreeSet?? 有序 ,不可重復

?

public class TreeSet<E> extends AbstractSet<E> implements NavigableSet<E>, Cloneable, Serializable

?

?

常用方法? 來自Collection

?

?

范例: 觀察TreeSet子類的使用

public static void main(String[] args) {

????????? Set<String> all=new TreeSet<>();

?????????

????????? all.add("B");

?????????

????????? all.add("C");

?????????

????????? all.add("A");

?????????

????????? all.add("C");? //重復元素

?????????

????????? for(String str:all) {

??????????????

?????????????? System.out.println(str);

????????? }

???? }

?

通過觀察以上代碼發現,TreeSet 存放的數據有以下兩個特點:

?

1 有序?? 為什么有序?

?

TreeSet的排序是通過compreable 接口中的compareTo方法完成的 該方法返回 3個取值

?

分別為: 1 升序?? - 1 降序?? 0 重復元素的判斷

范例: 使用自定義類完成TreeSet

?

public static void main(String[] args) {

?????????

?????????

????????? Set<Person> all=new TreeSet<>();

?????????

????????? all.add(new Person("張三",32));

?????????

????????? all.add(new Person("李四",20));

?????????

????????? all.add(new Person("張三",32));

?????????

????????? all.add(new Person("隔壁老王",89));? //重復元素

?????????

????????? for(Person per:all) {

??????????????

?????????????? System.out.println(per);

????????? }

???? }

?

出錯了以下的錯誤:

Exception in thread "main" java.lang.ClassCastException: org.list.Person cannot be cast to java.lang.Comparable

???? at java.util.TreeMap.compare(Unknown Source)

???? at java.util.TreeMap.put(Unknown Source)

???? at java.util.TreeSet.add(Unknown Source)

???? at org.set.TreeSetDemo.main(TreeSetDemo.java:15)

?

說明在TreeSet中進行保存的時候,約定存儲的類型必須實現一個接口,而這個接口就是comparable接口,如果沒有這個接口則不能實現排序功能

?

范例:實現compareTo方法

@Override

???? public int compareTo(Person o) {

????????? // TODO Auto-generated method stub

????????? if(this.age>o.age) {

?????????????? return 1;

????????? }else if(this.age<o.age) {

?????????????? return -1;

????????? }

????????? return 0;

???? }

?

?

?

?

2 不可重復

?重復元素的區分 在TreeSet中是依靠compareTo方法是否返回0來判斷的

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的JAVA复习5(TreeSet)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。