찾다
Javajava지도 시간Java에서 집합 컬렉션을 적용하는 방법

ㅋㅋㅋ 일반적인 for 루프 순회를 사용할 수 없으며 index

Java에서 집합 컬렉션을 적용하는 방법


Set 컬렉션 구현 클래스 기능으로 요소를 얻을 수 없습니다.

HashSet: 순서가 지정되지 않음, 반복되지 않음, 인덱스 없음

LinkedHashSet: 순서가 지정됨, 반복되지 않음, 인덱스 없음
  • TreeSet: 정렬, 중복 없음, 색인 없음

    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);

출력 결과:

위 코드를 출력 결과와 비교하면 순서가 없는 것과 순서가 있는 것의 차이를 알 수 있습니다. 데이터는 중단되지만 후자는 여전히 입력 데이터의 순서대로 데이터를 저장하므로 출력은 정렬된 상태입니다.

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);

출력 결과:

Java에서 집합 컬렉션을 적용하는 방법

위의 코드와 출력 결과를 통해 왜 TreeSet이 정렬을 특징으로 하는지, 저장되는 데이터는 Java에 따른 것인지 말 그대로 이해할 수 있습니다. 기본 정렬 방식으로 정렬합니다.

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=&#39;" + name + &#39;\&#39;&#39; +
                ", age=" + age +
                ", classroom=&#39;" + classroom + &#39;\&#39;&#39; +
                &#39;}&#39;;
    }
}
//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 메서드를 재정의하여 지정하는 것입니다. 규칙; 다른 하나는 규칙을 정의하기 위해 자체 비교기 개체가 있는 컬렉션을 사용하는 것입니다.

방법 1: 클래스를 사용자 정의하여 Comparable 인터페이스를 구현하고 CompareTo 메서드를 다시 작성하여 비교 규칙을 지정합니다(중복되고 관련 없는 코드는 여기서 설명하지 않고 코드의 중요한 부분만 표시합니다)

//改变的第一个地方:实现Comparable类
public class People implements Comparable<People> {
//改变的第二个地方:重写Comparable类中的compareTo方法    
    @Override
    public int compareTo(People o) {
        return this.age-o.age;
    }
}

출력 결과 (나이 기준) 비교):

Java에서 집합 컬렉션을 적용하는 방법재정의된 메서드에서 반환 후의 코드는 개체가 어떤 기준에 따라 비교될지 결정합니다. 비교 규칙은 다음과 같습니다.

첫 번째 요소를 고려하는 경우. 두 번째 요소보다 크려면 양의 정수만 반환하세요

첫 번째 요소가 두 번째 요소보다 작다고 생각되면 음의 정수를 반환하세요

Java에서 집합 컬렉션을 적용하는 방법

첫 번째 요소가 두 번째 요소와 같다고 생각되면 요소, 그냥 0을 반환합니다. 이때 Treeset 컬렉션은 요소 하나만 유지하고 두 요소를 중복으로 간주합니다

방법 2: 세트에는 규칙 정의를 위한 자체 비교기 개체가 함께 제공됩니다

Set<People> p = new TreeSet<>(new Comparator<People>() {
            @Override
            public int compare(People o1, People o2) {
                return o1.getAge()-o2.getAge();
            }
        });

생성 변경 원본을 기반으로 한 세트 및 비교 기준은 이전 정의 방법과 유사하며 이전 방법과 비교하여 이 방법이 더 편리하고 빠릅니다. 이전에 배운 Lambda 표현식을 사용하여 이 코드 블록을 단순화할 수 있습니다.

아아아아

위 내용은 Java에서 집합 컬렉션을 적용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 亿速云에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
带你搞懂Java结构化数据处理开源库SPL带你搞懂Java结构化数据处理开源库SPLMay 24, 2022 pm 01:34 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于结构化数据处理开源库SPL的相关问题,下面就一起来看一下java下理想的结构化数据处理类库,希望对大家有帮助。

Java集合框架之PriorityQueue优先级队列Java集合框架之PriorityQueue优先级队列Jun 09, 2022 am 11:47 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于PriorityQueue优先级队列的相关知识,Java集合框架中提供了PriorityQueue和PriorityBlockingQueue两种类型的优先级队列,PriorityQueue是线程不安全的,PriorityBlockingQueue是线程安全的,下面一起来看一下,希望对大家有帮助。

完全掌握Java锁(图文解析)完全掌握Java锁(图文解析)Jun 14, 2022 am 11:47 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于java锁的相关问题,包括了独占锁、悲观锁、乐观锁、共享锁等等内容,下面一起来看一下,希望对大家有帮助。

一起聊聊Java多线程之线程安全问题一起聊聊Java多线程之线程安全问题Apr 21, 2022 pm 06:17 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了线程安装、线程加锁与线程不安全的原因、线程安全的标准类等等内容,希望对大家有帮助。

详细解析Java的this和super关键字详细解析Java的this和super关键字Apr 30, 2022 am 09:00 AM

本篇文章给大家带来了关于Java的相关知识,其中主要介绍了关于关键字中this和super的相关问题,以及他们的一些区别,下面一起来看一下,希望对大家有帮助。

Java基础归纳之枚举Java基础归纳之枚举May 26, 2022 am 11:50 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于枚举的相关问题,包括了枚举的基本操作、集合类对枚举的支持等等内容,下面一起来看一下,希望对大家有帮助。

java中封装是什么java中封装是什么May 16, 2019 pm 06:08 PM

封装是一种信息隐藏技术,是指一种将抽象性函式接口的实现细节部分包装、隐藏起来的方法;封装可以被认为是一个保护屏障,防止指定类的代码和数据被外部类定义的代码随机访问。封装可以通过关键字private,protected和public实现。

归纳整理JAVA装饰器模式(实例详解)归纳整理JAVA装饰器模式(实例详解)May 05, 2022 pm 06:48 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于设计模式的相关问题,主要将装饰器模式的相关内容,指在不改变现有对象结构的情况下,动态地给该对象增加一些职责的模式,希望对大家有帮助。

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경