如何在自定义集合中使用`Collections.min()`?

问题描述 投票:1回答:1

我写了一个名为MySet<T>的自定义集合,它基本上是HashSet的包装器:

import java.util.Collections;
import java.util.HashSet;

public class MySet <T> {
    private HashSet<T> set;

    public MySet() {
        this.set = new HashSet<>();
    }

    public MySet(T[] elements) {
        this.set = new HashSet<>();
        Collections.addAll(this.set, elements);
    }
    public HashSet<T> getSet() {
        return this.set;
    }
}

它包含与union()intersect()等集合相关的方法。

我还写了一个名为Person的类,它代表一个人的基本细节并实现Comparable接口:

public class Person implements Comparable<Person> {
    private int id;
    private String name;
    private int age;

    public Person(int id, int age, String name) {
        this.id = id;
        this.age = age;
        this.name = name;
    }

    private boolean equals(Person p) {
        return this.age == p.age;
    }

    public int compareTo(Person p) {
        return this.age - p.age;
    }
}

我们比较基于Person字段的age对象。

我需要编写第三个类,它只有接收MySet<Person>对象的方法,并确定最小的Person。当然这可以通过使用两个循环来手动完成,以找到最小年龄,但重点是使用Java方法进行泛型,所以我在Collections.min()上使用MySet<Person>

public class MinimumClass<T> {
    public T minElement(MySet<T> set) {
        Collections.min(set);
    }
}

哪个不编译并给出错误:no instance(s) of type variable(s) T exist so that MySet<T> conforms to Collection<? extends T>据我所知,这意味着我必须在Collection中实现MySet接口。

是否有一种更简单的方法来编写使用Person实现ComparableMySet是通用类的事实来确定最小人的方法?

java generics collections comparison min
1个回答
2
投票

由于HashSetCollection,你可以在上面打电话给Collections.min。请注意,为了使用T,您应该将其限制为Comparable Collections.min

public class MinimumClass<T extends Comparable<T>> {
    public T minElement(MySet<T> mySet) {
        return Collections.min(mySet.getSet());
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.