이 게시물 시리즈에서는 동일한 기능을 코딩하는 다양한 방법을 비교하고 있습니다. 마지막 게시물에서는 단일 요소 목록을 생성하기 위해 Collections.singletonList와 ArrayList를 비교했습니다.
이 게시물에서는 Collections.singletonList와 또 다른 잘 알려진 팩토리 메소드인 List.of를 비교해 보겠습니다.
공용 정적
public static void main(String[] args) { final var addresses = Collections.singletonList( new Address( "742 Evergreen Terrace", "Springfield", "New York", "13468", "US" )); System.out.println(addresses); }
이 메소드는 지정된 객체만 포함하는 변경 불가능한 목록을 반환합니다. Java 1.3에서 도입되었습니다. ArrayList에 비해 장점은 지난 게시물에서 다루었지만 요약하자면:
정적
public static void main(String[] args) { final var addresses2 = List.of( new Address( "1007 Mountain Drive", "Bristol Township", "New Jersey", null, "US" )); System.out.println(addresses2); }
List.of(E e) 메소드는 수정 불가능한 목록을 반환하는 팩토리 메소드이기도 합니다. 하나의 요소만 지원하는 Collections.singletonList(E e)와 달리 List.of는 0~10개의 요소와 여러 요소가 있는 배열을 지원합니다. SingletonList 이후 17년 만에 Java 9에서 도입되었습니다.
다음 주석이 있는 SingletonList와는 달리 흥미로운 점은 다음과 같습니다.
지정된 객체만 포함하는 불변 목록을 반환합니다.
Array.of는 수정할 수 없는 목록:
이라고 명시합니다.하나의 요소를 포함하는 수정 불가능한 목록을 반환합니다.
이는 컬렉션의 불변성에 대한 새로운 이해를 반영합니다. 이 문서에 따르면:
요소를 추가, 제거 또는 교체할 수 없는 경우 컬렉션은 수정 불가능한 것으로 간주됩니다. 그러나 수정 불가능한 컬렉션은 컬렉션에 포함된 요소가 변경 불가능한 경우에만 변경할 수 없습니다.
이러한 용어 차이에도 불구하고 두 팩토리 메소드는 거의 동일한 기능을 갖습니다. UnmodifiedList를 더 자세히 살펴보면 다음을 찾을 수 있습니다.
staticList of(E e1) { return new ImmutableCollections.List12(e1); }
그렇지만 그들은 그다지 정확하지 않은 용어 불변을 사용했다는 사실이 정말 놀랍습니다!
static final class List12extends AbstractImmutableList implements Serializable { @Stable private final E e0; @Stable private final E e1; List12(E e0) { this.e0 = Objects.requireNonNull(e0); this.e1 = null; } ... }
static abstract class AbstractImmutableListextends AbstractImmutableCollection implements List , RandomAccess { // all mutating methods throw UnsupportedOperationException @Override public void add(int index, E element) { throw uoe(); } @Override public boolean addAll(int index, Collection extends E> c) { throw uoe(); } @Override public E remove(int index) { throw uoe(); } @Override public void replaceAll(UnaryOperator operator) { throw uoe(); } @Override public E set(int index, E element) { throw uoe(); } @Override public void sort(Comparator super E> c) { throw uoe(); }
유일한 차이점은 List12에는 잠재적으로 두 개의 요소에 대한 두 개의 필드가 있다는 것입니다. 이는 또한 큰 개체를 처리하지 않는 한 무시할 수 있는 메모리 공간을 초래합니다.
이번에는 단일 요소 목록을 생성하기 위해 Collections.singletonList와 List.of 팩토리 메소드를 비교했습니다. 우리는 불변 및 수정 불가능의 의미에 대해 논의했으며 두 방법 모두 효율적이고 간결하며 리소스가 가볍다는 것을 보여주었습니다. 최신 Java 버전을 사용할 수 있다면 익숙함과 명확성 그리고 컬렉션보다 목록 인터페이스를 훨씬 더 많이 사용하기 때문에 선호됩니다. 이전 Java 버전으로 제한된 경우 Collections.singletonList는 여전히 확실한 선택입니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3