我写了一个名为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
实现Comparable
和MySet
是通用类的事实来确定最小人的方法?
由于HashSet
是Collection
,你可以在上面打电话给Collections.min
。请注意,为了使用T
,您应该将其限制为Comparable
Collections.min
。
public class MinimumClass<T extends Comparable<T>> {
public T minElement(MySet<T> mySet) {
return Collections.min(mySet.getSet());
}
}