Java에서 집합 컬렉션을 이해하는 방법
이 글은 집합 컬렉션과 관련된 문제를 주로 소개하는 java에 대한 관련 지식을 제공합니다. 집합 컬렉션의 특징은 순서가 없고, 반복되지 않으며, 색인이 없음을 함께 살펴보겠습니다. 모두가 도움이 됩니다.
추천 학습: "java 비디오 튜토리얼"
세트 컬렉션 기능:
- 순서 없음: 액세스 순서가 일치하지 않습니다.
- 중복 없음: 중복 제거 가능
- 색인 없음: 있음 는 색인화 방법이 아니므로 일반적인 for 루프 순회를 사용할 수 없으며 색인을 통해 요소를 얻을 수도 없습니다
Set 컬렉션 구현 클래스 기능:
HashSet: 순서 없음, 비반복, 색인 없음
LinkedHashSet: Ordered, non-duplicate, no index
TreeSet: Sort, non-duplicate, no index
Set 컬렉션의 기능은 기본적으로 Collection의 API와 동일합니다.
HashSet 컬렉션
HashSet 컬렉션:
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);
로그인 후 복사
출력 결과: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);
로그인 후 복사
출력 결과: 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);
위의 코드와 출력 결과를 통해 TreeSet의 특징이 정렬인 이유와 저장되는 데이터가 정렬에 따라 저장되는 이유를 문자 그대로 이해할 수 있습니다. Java의 기본 정렬 방법을 기준으로 정렬합니다.
단, 이때 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); }
One
은 클래스를 사용자 정의하여 Comparable 인터페이스를 구현하고 CompareTo 메서드를 재정의하는 것입니다. 규칙을 지정하기 위해 ;The other
는 규칙 정의를 위한 자체 비교기 개체가 있는 컬렉션입니다.방법 1: Custom 클래스는 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(); } });
Set<People> p = new TreeSet<>((o1, o2) -> o1.getAge()-o2.getAge());
추천 학습: "java 비디오 튜토리얼"
위 내용은 Java에서 집합 컬렉션을 이해하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Java의 난수 생성기 안내. 여기서는 예제를 통해 Java의 함수와 예제를 통해 두 가지 다른 생성기에 대해 설명합니다.

Java의 Weka 가이드. 여기에서는 소개, weka java 사용 방법, 플랫폼 유형 및 장점을 예제와 함께 설명합니다.

Java의 Smith Number 가이드. 여기서는 정의, Java에서 스미스 번호를 확인하는 방법에 대해 논의합니다. 코드 구현의 예.

이 기사에서는 가장 많이 묻는 Java Spring 면접 질문과 자세한 답변을 보관했습니다. 그래야 면접에 합격할 수 있습니다.

Java 8은 스트림 API를 소개하여 데이터 컬렉션을 처리하는 강력하고 표현적인 방법을 제공합니다. 그러나 스트림을 사용할 때 일반적인 질문은 다음과 같은 것입니다. 기존 루프는 조기 중단 또는 반환을 허용하지만 스트림의 Foreach 메소드는이 방법을 직접 지원하지 않습니다. 이 기사는 이유를 설명하고 스트림 처리 시스템에서 조기 종료를 구현하기위한 대체 방법을 탐색합니다. 추가 읽기 : Java Stream API 개선 스트림 foreach를 이해하십시오 Foreach 메소드는 스트림의 각 요소에서 하나의 작업을 수행하는 터미널 작동입니다. 디자인 의도입니다

Java의 TimeStamp to Date 안내. 여기서는 소개와 예제와 함께 Java에서 타임스탬프를 날짜로 변환하는 방법에 대해서도 설명합니다.

캡슐은 3 차원 기하학적 그림이며, 양쪽 끝에 실린더와 반구로 구성됩니다. 캡슐의 부피는 실린더의 부피와 양쪽 끝에 반구의 부피를 첨가하여 계산할 수 있습니다. 이 튜토리얼은 다른 방법을 사용하여 Java에서 주어진 캡슐의 부피를 계산하는 방법에 대해 논의합니다. 캡슐 볼륨 공식 캡슐 볼륨에 대한 공식은 다음과 같습니다. 캡슐 부피 = 원통형 볼륨 2 반구 볼륨 안에, R : 반구의 반경. H : 실린더의 높이 (반구 제외). 예 1 입력하다 반경 = 5 단위 높이 = 10 단위 산출 볼륨 = 1570.8 입방 단위 설명하다 공식을 사용하여 볼륨 계산 : 부피 = π × r2 × h (4
