Comparable 및 Comparator를 사용하여 Java에서 재정렬을 제거하는 방법
1. 정렬 및 중복 제거
일상 작업에는 항상 결과 집합을 필터링해야 하는 몇 가지 시나리오가 있습니다. 예를 들어, 제3자와 상호 작용한 후 얻은 결과 집합을 다시 정렬하고 중복 제거해야 하는 경우 결과 집합은 특정 필드에 따라 중복 제거되거나 특정 필드별로 정렬됩니다.
자바에서는 중복제거를 하면 Set(순서없음, 중복없음)의 특징을 쉽게 떠올릴 수 있고, TreeSet(순서있음, 중복없음)도 중복제거에 대한 규칙을 지정할 수 있습니다(중복제거 후 결과는 일반적으로 오름차순) 설정).
정렬이라고 하면 다양한 정렬 알고리즘을 쉽게 생각할 수 있지만 Java는 이미 컬렉션에 sort() 메서드와 같은 정렬 기능을 제공하고 있으며 정렬 필드와 오름차순 및 내림차순을 지정할 수도 있습니다.
여기서 한 가지 더 말씀드리자면, 세트의 특징(순서 없음 및 중복 없음):
무질서: 무질서는 무작위가 아닙니다. 세트에 배치된 요소는 해시 값에 따라 결정되기 때문입니다. 요소의 배치된 위치
-
는 가중치가 없습니다. 요소를 추가할 때 두 요소가 동일하지 않은 것으로 false로 간주되면 요소가 추가됩니다.
2. Comparable 및 Comparator의 사용
public class CompareTest { public static void main(String[] args) { // 例如:从第三方返回的结果集 // 根据id去重,根据createTime降序排列 String result = "[" + "{ \"id\": 1, \"createTime\": \"2022-12-21 13:23:59\"}" + "{ \"id\": 2, \"createTime\": \"2022-11-11 12:43:01\"}" + "{ \"id\": 1, \"createTime\": \"2022-12-21 11:20:50\"}" + "{ \"id\": 3, \"createTime\": \"2023-01-01 14:30:00\"}" + "]"; JSONArray examList = JSONArray.parseArray(result); System.out.println("初始数据集:" + examList); // 去重,利用set特性 Comparator<JSONObject> comparator = (a, b) -> Integer.compare(a.getIntValue("id"), b.getIntValue("id")); Set<JSONObject> set = new TreeSet<>(comparator); examList.forEach(jo -> set.add((JSONObject) jo)); // 此时的结果是,根据id去重,并且是升序的结果(自然排序) System.out.println("去重结果:" + set); // 此处为了,方便演示Comparable接口的作用,故把JSON映射成实体类,进行实现接口排序,其实sorted也可以使用Comparator排序 List<ExamInfo> collect = set.stream() .map(jo -> JSONObject.toJavaObject(jo, ExamInfo.class)) .sorted() .collect(Collectors.toList()); System.out.println("指定排序结果:" + collect); } }
public class ExamInfo implements Comparable<ExamInfo> { private int id; private String createTime; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getCreateTime() { return createTime; } public void setCreateTime(String createTime) { this.createTime = createTime; } @Override public String toString() { return "ExamInfo{" + "id=" + id + ", createTime='" + createTime + '\'' + '}'; } @Override public int compareTo(ExamInfo o) { // 降序 return o.getCreateTime().compareTo(this.createTime); } }
오름차순 및 내림차순 정렬 문제와 관련하여 Comparable 및 Comparator의 비교 메서드의 반환 값이 0보다 큰 경우 교환됩니다.
그래서 매개변수 순서가 a,b인 경우:
만약 a>b 즉, a-b>0이면 순서가 a,b이므로 교환 후 b가 앞에, a가 in입니다. 뒷면은 정렬 순서 오름차순, 즉 자연스러운 정렬
// 升序 Comparator<JSONObject> comparator = (a, b) -> Integer.compare(a.getIntValue("id"), b.getIntValue("id"));
교환 후 순서가 a, b이므로 b>a, 즉 b-a>0, b가 앞에 있고, a가 뒤에 있으며, 정렬 순서는 내림차순입니다.
@Override public int compareTo(ExamInfo o) { // 降序 return o.getCreateTime().compareTo(this.createTime); }
3. 차이점
Comparable | Comparator | |
---|---|---|
패키지 | java.lang | java.util |
기능적인 인터페이스인가요 | 예 | 은 |
비교 방법입니다 | int CompareTo(T o) | int Compare(T o1, T o2) |
사용 시나리오 | 비교 대상, 비교 대상을 수정할 수 있습니다. | , 직접 수정할 수 없거나 객체가 Comparable 인터페이스를 구현하지만 비교 규칙이 적용되지 않습니다 |
위 내용은 Comparable 및 Comparator를 사용하여 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
