可以使用Java中的TreeSet来实现按属性排序并保持唯一性的哈希集合。TreeSet是一种有序集合,它通过Comparator或Comparable接口对元素进行排序,同时它也是一个Set,保证集合中的元素是唯一的。
下面是一个示例代码:
import java.util.Comparator;
import java.util.TreeSet;
// 定义一个类作为集合中的元素
class Person {
private int id;
private String name;
public Person(int id, String name) {
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public String getName() {
return name;
}
@Override
public String toString() {
return "Person{" +
"id=" + id +
", name='" + name + '\'' +
'}';
}
}
// 自定义比较器,按照id属性进行排序
class PersonComparator implements Comparator {
@Override
public int compare(Person p1, Person p2) {
return Integer.compare(p1.getId(), p2.getId());
}
}
public class Main {
public static void main(String[] args) {
// 创建一个TreeSet,并使用自定义比较器进行排序
TreeSet people = new TreeSet<>(new PersonComparator());
// 向集合中添加元素
people.add(new Person(1, "Alice"));
people.add(new Person(3, "Bob"));
people.add(new Person(2, "Charlie"));
people.add(new Person(2, "David")); // 添加重复的元素,但id相同
// 遍历集合并输出
for (Person person : people) {
System.out.println(person);
}
}
}
输出结果:
Person{id=1, name='Alice'}
Person{id=2, name='Charlie'}
Person{id=3, name='Bob'}
在上述示例中,我们定义了一个Person类作为集合中的元素,该类包含id和name两个属性。我们还定义了一个自定义比较器PersonComparator,用于按id属性对Person对象进行排序。然后,我们使用TreeSet创建了一个有序集合people,并将自定义比较器传递给它。接下来,我们向集合中添加了几个Person对象,包括一个重复的对象。最后,我们遍历集合并输出结果,可以看到集合中的元素按照id属性进行了排序,并且重复的元素被去除了。
上一篇:按属性名分组,以首字母为准。
下一篇:按属性排序的XQUERY