ㅋㅋㅋ 일반적인 for 루프 순회를 사용할 수 없으며 index
Set 컬렉션 구현 클래스 기능으로 요소를 얻을 수 없습니다.
HashSet: 순서가 지정되지 않음, 반복되지 않음, 인덱스 없음
LinkedHashSet: 순서가 지정됨, 반복되지 않음, 인덱스 없음Set<String> set = new HashSet<>(); set.add("石原里美"); set.add("石原里美"); set.add("工藤静香"); set.add("朱茵"); System.out.println(set); set.remove("朱茵"); System.out.println(set);
위의 코드와 실행 결과를 통해 HashSet 컬렉션이 순서가 없고 반복되지 않음을 분명히 알 수 있습니다. 위 그림을 보면 HashSet 컬렉션은 get() 메소드의 인덱스를 통해서는 데이터를 얻을 수 없고, 컬렉션에 있는 데이터를 삭제하는 경우에는 방향 삭제를 통해서만 데이터를 삭제할 수 있음을 알 수 있다. LinkedHashSet 집합:
LinkedHashSet 집합:
Set<String> set = new LinkedHashSet<>(); set.add("石原里美"); set.add("石原里美"); set.add("工藤静香"); set.add("朱茵"); System.out.println(set); set.remove("朱茵"); System.out.println(set);
출력 결과:
위 코드를 출력 결과와 비교하면 순서가 없는 것과 순서가 있는 것의 차이를 알 수 있습니다. 데이터는 중단되지만 후자는 여전히 입력 데이터의 순서대로 데이터를 저장하므로 출력은 정렬된 상태입니다. TreeSet 컬렉션: TreeSet 컬렉션:Set<Integer> set = new TreeSet<>(); set.add(13); set.add(23); set.add(23); set.add(11); System.out.println(set); set.remove(23); System.out.println(set);
단, 이때 People 객체 등의 Custom 객체를 저장하면 TreeSet을 직접 정렬할 수 없어 오류가 발생하게 됩니다!
//People类: public class People{ private String name; private int age; private String classroom; public People(){ } public People(String name, int age, String classroom) { this.name = name; this.age = age; this.classroom = classroom; } 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; } public String getClassroom() { return classroom; } public void setClassroom(String classroom) { this.classroom = classroom; } @Override public String toString() { return "People{" + "name='" + name + '\'' + ", age=" + age + ", classroom='" + classroom + '\'' + '}'; } } //main方法: public static void main(String[] args) { Set<People> p = new TreeSet<>(); p.add(new People("张三",19,"智能")); p.add(new People("李四",18,"数据库")); p.add(new People("王五",20,"渗透")); System.out.println(p); }
이 문제를 해결하려면 TreeSet 컬렉션의 저장 유형을 사용자 정의해야 합니다. 이 문제를 해결하는 방법에는 두 가지가 있습니다. 하나는 클래스를 사용자 정의하여 Comparable 인터페이스를 구현하고 CompareTo 메서드를 재정의하여 지정하는 것입니다. 규칙; 다른 하나는 규칙을 정의하기 위해 자체 비교기 개체가 있는 컬렉션을 사용하는 것입니다.
//改变的第一个地方:实现Comparable类 public class People implements Comparable<People> { //改变的第二个地方:重写Comparable类中的compareTo方法 @Override public int compareTo(People o) { return this.age-o.age; } }
출력 결과 (나이 기준) 비교):
재정의된 메서드에서 반환 후의 코드는 개체가 어떤 기준에 따라 비교될지 결정합니다. 비교 규칙은 다음과 같습니다.
첫 번째 요소가 두 번째 요소보다 작다고 생각되면 음의 정수를 반환하세요
첫 번째 요소가 두 번째 요소와 같다고 생각되면 요소, 그냥 0을 반환합니다. 이때 Treeset 컬렉션은 요소 하나만 유지하고 두 요소를 중복으로 간주합니다방법 2: 세트에는 규칙 정의를 위한 자체 비교기 개체가 함께 제공됩니다Set<People> p = new TreeSet<>(new Comparator<People>() { @Override public int compare(People o1, People o2) { return o1.getAge()-o2.getAge(); } });
아아아아
위 내용은 Java에서 집합 컬렉션을 적용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!