溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

根據(jù)list中對象的屬性去重和排序小結(jié)(必看篇)

發(fā)布時(shí)間:2020-09-01 10:41:48 來源:腳本之家 閱讀:233 作者:jingxian 欄目:編程語言

如下所示:

//去重
public class User {
    private int id;
    private String name;
    private int age;
    public User(){}
    public User(int id, String name, int age) {
      super();
      this.id = id;
      this.name = name;
      this.age = age;
    }
    public int getId() {
      return id;
    }
    public void setId(int id) {
      this.id = id;
    }
    public String getName() {
      return name;
    }
    public void setName(String name) {
      this.name = name;
    }
    public int getAge() {
      return age;
    }
    public void setAge(int age) {
      this.age = age;
    }
    @Override
    public String toString() {
      return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
    }
     
  }

public class ListTest {
/**
 *   有一個(gè)List<User> list 放了五個(gè)對象:user1、user2、user3、user4、user5
  User有三個(gè)屬性Id、name、age
  其中user2的記錄大概是這樣:“100”,"abc",20;
  user3的記錄大概是這樣:“100”,“def”,20;
  請問怎么才能只保留user2和user3中的一個(gè)對象,并將其中的name合并到新對象中,
  新對象如“100”,“abcdef”,20
  這只是舉個(gè)例子,實(shí)際中有可能user4和user5與此類似,如果有id相同的兩個(gè)對象,則對其進(jìn)行
  合并,只保留一個(gè)對象,求一個(gè)通用的方法,能篩選出對象集合中某些相同ID的兩個(gè)對象,將其合并
  仍保留在原list中
 * @param args
 */
  //list有序可重復(fù)、set無序不可重復(fù)、mapkey不允許重復(fù),key相同的后面的value會(huì)把前面的覆蓋掉
  //List存放的數(shù)據(jù),默認(rèn)是按照放入時(shí)的順序存放的,比如依次放入A、B、C,則取得時(shí)候,則也是A、B、C的順序
  public static void main(String[] args) {
    List<User> list = new ArrayList<>();
    list.add(new User(1,"a",20));
    list.add(new User(1,"a",20));
    list.add(new User(2,"a",20));
    list.add(new User(3,"b",20));
    list.add(new User(1,"c",20));
    list.add(new User(4,"d",20));
    list.add(new User(2,"e",20));
    list.add(new User(1,"a",20));
    /* for (User user : list) {
      System.out.println(user.toString());
    } 
    System.out.println();*/
    list = mySort(list);
    for (User user : list) {
      System.out.println(user.toString());
    }
       
    }
    public static List<User> mySort(List<User> list){
      HashMap<Integer,User> tempMap = new HashMap<>();
      for (User user : list) {
        int key = user.getId();
// containsKey(Object key) 該方法判斷Map集合對象中是否包含指定的鍵名。如果Map集合中包含指定的鍵名,則返回true,否則返回false
// containsValue(Object value)  value:要查詢的Map集合的指定鍵值對象.如果Map集合中包含指定的鍵值,則返回true,否則返回false
        if(tempMap.containsKey(key)){
          User tempUser = new User(key,
                       tempMap.get(key).getName() + user.getName(),
                       tempMap.get(key).getAge());//user.getAge();
//HashMap是不允許key重復(fù)的,所以如果有key重復(fù)的話,那么前面的value會(huì)被后面的value覆蓋          
          tempMap.put(key, tempUser);
        }else{
          tempMap.put(key, user);
        }
      }
      List<User> tempList = new ArrayList<>();
      for(int key : tempMap.keySet()){
        tempList.add(tempMap.get(key));
      }
      return tempList;
    }

  }

//排序=============================================
public class Student {
  private int age; 
  private String name; 
  public int getAge() { 
    return age; 
  } 
 
  public void setAge(int age) { 
    this.age = age; 
  } 

  public String getName() {
    return name;
  }

  public void setName(String name) {
    this.name = name;
  }

  @Override
  public String toString() {
    return "Student [age=" + age + ", name=" + name + "]";
  } 
  
}
public class ListSort {

  public static void main(String[] args) {
     List<Student> list = new ArrayList<Student>(); 
     
      //創(chuàng)建3個(gè)學(xué)生對象,年齡分別是20、19、21,并將他們依次放入List中 
      Student s1 = new Student(); 
      s1.setAge(20); 
      s1.setName("葛大");
      Student s2 = new Student(); 
      s2.setAge(19); 
      s2.setName("張杰");
      Student s3 = new Student(); 
      s3.setAge(21); 
      s3.setName("寶爺");
      list.add(s1); 
      list.add(s2); 
      list.add(s3); 
       
      System.out.println("排序前:"+list); 
      
      Collections.sort(list, new Comparator<Student>(){ 
   
        /* 
         * int compare(Student o1, Student o2) 返回一個(gè)基本類型的整型, 
         * 返回負(fù)數(shù)表示:o1 小于o2, 
         * 返回0 表示:o1和o2相等, 
         * 返回正數(shù)表示:o1大于o2。 
         */ 
        public int compare(Student o1, Student o2) { 
         
          //按照學(xué)生的年齡進(jìn)行升序排列 ;<是降序
//          /*if(o1.getAge() > o2.getAge()){ 
//            return 1; 
//          } 
//          if(o1.getAge() == o2.getAge()){ 
//            return 0; 
//          } 
//          return -1; */
//          return o1.getAge()-o2.getAge();//升序
//          return o2.getAge()-o1.getAge();//降序 
          return o1.getName().compareTo(o2.getName()) ;// 按照姓名升序
//          return o2.getName().compareTo(o1.getName()) ;// 按照姓名降序
        } 
      });  
      System.out.println("排序后:"+list); 
    } 

  }

以上這篇根據(jù)list中對象的屬性去重和排序小結(jié)(必看篇)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI