자바 Arrays.AsList 원리 및 용법 인 스 턴 스
1.집합 에 요 소 를 추가 하거나 삭제 하 는 작업 이 잘못 되 었 습 니 다.
다음 코드:
List list = Arrays.asList("a","b","c");
list.add("d");
출력 결과:
Exception in thread "main" java.lang.UnsupportedOperationException
at java.util.AbstractList.add(AbstractList.java:148)
at java.util.AbstractList.add(AbstractList.java:108)
at ArraysAsListTest.main(ArraysAsListTest.java:7)
Arrays.asList 의 원본 코드 는 ArrayList 를 되 돌려 주지 만 이 ArrayList 는 Arrays 내부 의 정적 클래스(java.util.Arrays.Array List)입 니 다.우리 가 평소에 사용 하 는 java.util.Array List 는 이름 만 같 고 가방 이름 이 다 릅 니 다.
이 Array List 도 AbstractList 에서 계승 되 었 으 나 add(),reove()방법 은 이 두 가지 방법 으로 AbstractList 의 기본 방법 을 호출 하 였 습 니 다.
public void add(int index, E element) {
throw new UnsupportedOperationException();
}
"Unsupported Operation Exception"의 이상 을 직접 던 집 니 다!그래서 우리 가 이 Array List 의 add 방법 을 호출 할 때 추상 적 인 집합 류 의 add 방법 을 호출 하여 위의 이상 을 던 졌 다.이 유 는 배열 이 집합 을 전환 하 는 방법 을 제 공 했 지만 본질 적 으로 배열 이 고 배열 의 길 이 는 고정 적 이기 때문에 jdk 의 작 가 는 add()와 reove()방법 을 실현 하지 못 했 기 때문이다.
여러분 이 사용 할 때 주의해 야 할 것 은 구체 적 인 업무 장면 과 결합 하여 판단 해 야 합 니 다.전 환 된 집합 만 옮 겨 다 니 거나 stream()흐름 을 사용 하 는 것 도 문제 가 없 으 면 정상적으로 사용 할 수 있 습 니 다(요 소 를 수정 해도 문제 가 없습니다).그러나 원 소 를 추가 하거나 삭제 하 는 등 집합 길 이 를 바 꾸 는 작업 이 필요 하 다 면 피해 야 합 니 다.그렇지 않 으 면 잘못 보고 하면 우리 의 정상 적 인 업무 논리 에 영향 을 줄 것 이다.
길이
아니면 Arrays 의 asList()입 니까?이 방법 은 기본 유형의 배열 을 집합 List 로 바 꿀 수 없습니다.또는 기본 유형 은 성공 적 으로 바 꿀 수 있 지만'우리 가 원 하 는 집합'이 아 닙 니 다.asList 방법 은 일반적인 길이 변 하 는 매개 변 수 를 받 기 때 문 입 니 다.
기본 데이터 형식 은 일반화 할 수 없다.그러면 일반화 에 있어 기본 데이터 형식 은'[x'의 유형 으로 여 겨 진다.'['는 이것 이 하나의 배열 이 고'x'는 현재 배열 의 유형 임 을 나타 낸다.예 를 들 어 int[]는 실제 유형 이'[I'이다.
이렇게 되면 Arrays.asList 에서 들 어 오 는 매개 변 수 는 기본 형식 이 라면 배열 을 하나의 요소 로 처리 합 니 다(길이=1).만약 에 우리 가 List 를 옮 겨 다 니 거나 List 의 길 이 를 가 져 오 려 면 정확 하지 않 습 니 다.아래 의 용법 과 같 습 니 다.
int array[] = {1,2,3,4,5};
List list = Arrays.asList(array);
System.out.println("길이="+list.size();
System.out.println("요소 3=포함 여부"+list.contains(3);
출력 결과:
길이=1 원소 3=false 포함 여부
만약 우리 의 코드 에 이렇게 길 이 를 얻 거나 지정 한 요 소 를 포함 하 는 지 판단 하 는 작업 이 사용 된다 면 쓰기 에 주의해 야 합 니 다.그렇지 않 으 면 우리 의 논리 적 절차 에 영향 을 줄 수 있 습 니 다!
이러한 문제 가 발생 하지 않도록 여러 가지 다른 표기 법 이 있 습 니 다.예 를 들 어 array 를 포장 류(즉 참조 유형)로 바 꾸 는 것 은 다음 과 같 습 니 다.
Integer array[] = {1,2,3,4,5};
List list = Arrays.asList(array);
System.out.println("길이="+list.size();
System.out.println("요소 3=포함 여부"+list.contains(3);
출력 결과:
길이=5 원소 포함 여부 3=true
물론 구 글 의 집합 클래스 인'Ints.asList'도 사용 할 수 있 습 니 다.다음 과 같 습 니 다.
int array[] = {1,2,3,4,5};
List list = Ints.asList(array);
System.out.println("길이="+list.size();
System.out.println("요소 3=포함 여부"+list.contains(3);
출력 결과:
길이=5 원소 포함 여부 3=true
그러나 구 글 의 Ints.asList 방법 이 되 돌아 오 는 list 도 자신 이 실현 한 집합 입 니 다.add 와 reove 방법 은 지원 되 지 않 습 니 다.list 로 변 환 된 데이터 길이 가 정확 하고 삭제 작업 이 가능 하 다 면 자바 util.Array List 를 사용 하 세 요.
3.Arrays.asList 방법 은 배열 의 보 기 를 되 돌려 줍 니 다.즉,이 list 에 대한 작업 은 원래 배열 에 반 영 됩 니 다.
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JPA + QueryDSL 계층형 댓글, 대댓글 구현(2)이번엔 전편에 이어서 계층형 댓글, 대댓글을 다시 리팩토링해볼 예정이다. 이전 게시글에서는 계층형 댓글, 대댓글을 구현은 되었지만 N+1 문제가 있었다. 이번에는 그 N+1 문제를 해결해 볼 것이다. 위의 로직은 이...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.