>Java >java지도 시간 >Java 13의 새로운 Records 클래스를 사용하여 데이터 객체를 그룹화하고 비정렬화합니다.

Java 13의 새로운 Records 클래스를 사용하여 데이터 객체를 그룹화하고 비정렬화합니다.

WBOY
WBOY원래의
2023-07-31 23:33:28784검색

Java 13의 새로운 Records 클래스를 사용하여 데이터 객체를 마샬링 및 비마샬링합니다.

Java가 계속 발전함에 따라 각 새 버전에는 몇 가지 새로운 기능과 개선 사항이 도입됩니다. Java 13에서는 불변 데이터 객체를 선언하고 사용하는 간결한 방법을 제공하는 새로운 Records 클래스가 도입되었습니다. 이 기사에서는 Records 클래스의 사용법을 소개하고 일부 샘플 코드를 통해 Records 클래스를 사용하여 데이터 개체를 마샬링 및 역마샬링하는 방법을 보여줍니다.

먼저 Records 클래스의 개념을 이해해 봅시다. Records 클래스는 클래스이자 인터페이스인 새로운 유형이며 불변 데이터 객체를 선언하는 데 사용됩니다. Records 클래스는 equals(), hashCode() 및 toString()과 같은 메서드를 포함한 기본 구현을 제공합니다. 또한 Records 클래스는 레코드 초기화를 위한 생성자를 자동으로 생성합니다. 일반 클래스와 달리 Records 클래스는 확장할 수 없으며 자체 필드와 메서드를 정의할 수 없습니다.

Record 클래스의 사용법을 설명하기 위해 간단한 예를 들어 보겠습니다. 이름과 나이를 포함하는 Person 객체가 있다고 가정합니다.

public record Person(String name, int age) {}

위 코드는 Records 클래스를 사용하여 선언된 Person 클래스를 정의합니다. Person 클래스에는 이름과 나이라는 두 개의 필드가 있습니다. 이제 Person 개체를 만들고 해당 필드에 액세스할 수 있습니다.

Person person = new Person("Alice", 30);
System.out.println(person.name()); // 输出:Alice
System.out.println(person.age()); // 输出:30

위에 표시된 것처럼 접근자 메서드(name() 및 age())를 통해 Person 개체의 필드 값을 가져올 수 있습니다. 또한 Records 클래스는 Person 객체를 직접 인쇄할 수 있도록 기본 toString() 메서드도 제공합니다.

다음으로 좀 더 복잡한 예를 살펴보겠습니다. Person 객체를 확장하고 학교 필드를 추가하는 Student 객체가 있다고 가정합니다.

public record Student(String name, int age, String school) implements Person {}

위 코드는 Person 클래스에서 상속되고 학교 필드를 추가하는 Student 클래스를 정의합니다. 동시에, Implements 키워드를 사용하여 Student 클래스가 Person 인터페이스의 구현 클래스임을 지정합니다. Records 클래스를 사용하여 선언된 객체는 일반 객체와 마찬가지로 클래스 상속 및 인터페이스 구현을 거칠 수 있습니다.

이제 Records 클래스를 사용하여 데이터 개체를 마샬링 및 역마샬링하는 방법을 살펴보겠습니다. Person 객체를 JSON 문자열로 변환하고 이를 파일에 저장한다고 가정해 보겠습니다.

import com.fasterxml.jackson.databind.ObjectMapper;

public class PersonSerialization {
    public static void main(String[] args) throws Exception {
        Person person = new Person("Alice", 30);
        
        // 编组为JSON字符串
        ObjectMapper mapper = new ObjectMapper();
        String jsonString = mapper.writeValueAsString(person);
        
        // 保存为文件
        FileWriter writer = new FileWriter("person.json");
        writer.write(jsonString);
        writer.close();
        
        System.out.println("Person对象已编组为JSON并保存到文件中");
    }
}

위 코드는 Jackson 라이브러리의 ObjectMapper 클래스를 사용하여 Person 개체를 JSON 문자열로 마샬링하고 파일에 저장합니다. mapper.writeValueAsString(person) 메소드를 호출하여 Person 객체를 JSON 문자열로 변환할 수 있습니다. 그런 다음 FileWriter 클래스를 사용하여 JSON 문자열을 파일에 씁니다.

그룹 해제 과정은 그룹화와 반대입니다. 파일에서 JSON 문자열을 읽고 이를 Person 객체로 역마샬링한다고 가정합니다.

import com.fasterxml.jackson.databind.ObjectMapper;

public class PersonDeserialization {
    public static void main(String[] args) throws Exception {
        // 从文件中读取JSON字符串
        String jsonString = Files.readString(Path.of("person.json"));
        
        // 解组为Person对象
        ObjectMapper mapper = new ObjectMapper();
        Person person = mapper.readValue(jsonString, Person.class);
        
        System.out.println("JSON已解组为Person对象:" + person);
    }
}

위 코드는 Files 클래스를 사용하여 파일에서 JSON 문자열을 읽고 ObjectMapper 클래스를 사용하여 JSON 문자열을 Person 개체로 역마샬링합니다. mapper.readValue(jsonString, Person.class) 메소드를 호출하여 JSON 문자열을 Person 객체로 변환할 수 있습니다.

요약하자면, 우리는 Java 13의 새로운 Records 클래스 사용법에 대해 배웠고 샘플 코드를 통해 Records 클래스를 사용하여 데이터 객체를 마샬링 및 비마샬링하는 방법을 시연했습니다. Records 클래스는 불변 데이터 객체를 선언하고 사용하는 간결한 방법을 제공하여 코드를 더 읽기 쉽고 안정적으로 만듭니다. Java 13 이상을 사용하는 경우 Records 클래스를 사용해 보고 프로젝트에 적용해 보세요.

위 내용은 Java 13의 새로운 Records 클래스를 사용하여 데이터 객체를 그룹화하고 비정렬화합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

관련 기사

더보기