arraylist 스레드는 안전합니까?
스레드 안전하지 않음:
스레드 안전성은 다중 스레드에 액세스할 때 잠금 메커니즘이 사용된다는 의미입니다. 스레드가 이 클래스의 특정 데이터에 액세스하면 해당 데이터가 보호되고 스레드가 이를 읽을 때까지 다른 스레드가 액세스할 수 없습니다. . 완료되었으므로 다른 스레드를 사용할 수 있습니다. 데이터 불일치나 데이터 오염이 발생하지 않습니다. 스레드 불안정성은 데이터 액세스 보호가 제공되지 않음을 의미합니다. 여러 스레드가 데이터를 연속적으로 변경하여 얻은 데이터가 더티 데이터가 될 수 있습니다.
ArrayList는 요소를 추가할 때 다음 두 단계로 완료될 수 있습니다.
1. 이 요소를 Items[Size] 위치에 저장합니다.
2. (추천 학습: Java 비디오 튜토리얼)
단일 스레드 작업의 경우 Size = 0이면 요소를 추가한 후 해당 요소는 위치 0에 있고 Size=1이면
; 다중 스레드, 예를 들어 두 개의 스레드가 있는 경우 스레드 A는 먼저 위치 0에 요소를 저장합니다. 그러나 이때 CPU는 스레드 A를 일시 중지하도록 예약하고 스레드 B가 실행될 기회를 얻습니다. 스레드 B도 이 ArrayList에 요소를 추가합니다. 왜냐하면 Size는 현재 여전히 0이기 때문입니다(요소를 추가하려면 두 단계가 필요하고 스레드 A는 1단계만 완료했다고 가정합니다). 따라서 스레드 B도 Stored at에 요소를 추가합니다. 위치 0. 그런 다음 스레드 A와 스레드 B가 모두 계속 실행되어 둘 다 Size 값이 증가합니다.
자, 이제 ArrayList의 상황을 살펴보겠습니다. 실제로는 위치 0에 요소가 하나만 저장되어 있지만 크기는 2입니다. 이것은 "안전하지 않은 스레드"입니다.
샘플 프로그램:
package test; importjava.util.ArrayList; import java.util.List; public class ArrayListInThread implements Runnable{ List<String> list1 = new ArrayList<String>();// not thread safe publicvoid run() { try { Thread.sleep((int)(Math.random() * 2)); } catch (InterruptedException e) { e.printStackTrace(); } list1.add(Thread.currentThread().getName()); } public static void main(String[] args) throws InterruptedException { ThreadGroup group = new ThreadGroup("mygroup"); ArrayListInThread t = new ArrayListInThread(); for (int i = 0; i < 10000; i++) { Thread th = new Thread(group, t,String.valueOf(i)); th.start(); } while (group.activeCount() > 0) { Thread.sleep(10); } System.out.println(); System.out.println(t.list1.size()); // it should be 10000 if thread safecollection is used. } }
스레드 불안을 해결하는 방법은 무엇입니까?
One: 모두가 익숙할 동기화 키워드를 사용하므로 설명하지 않겠습니다.
둘: Collections.synchronizedList()를 사용합니다.
만약 코드를 작성하면 List
칼럼!위 내용은 arraylist 스레드는 안전합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

1. Iterator와 foreach의 차이점은 다형성 차이입니다(foreach의 맨 아래 레이어는 Iterator입니다). Iterator는 인터페이스 유형이므로 컬렉션 유형이나 배열에 관심이 없습니다. for와 foreach 모두 컬렉션 유형을 알아야 합니다. 1. foreach의 최하위 레이어가 Iterator에 의해 작성된 코드라고 말하는 이유: 디컴파일된 코드: 2. foreach와 iterator에서 제거의 차이점을 살펴보세요. Alibaba Java Development Manual, 그러나 1번의 경우에는 오류가 보고되지 않으며, 2번의 경우(java.util.ConcurrentModificationException) 먼저 오류가 보고됩니다.

List 인터페이스의 contain() 메소드를 사용하여 목록에 객체가 존재하는지 확인할 수 있습니다. 포함() 메서드 booleancontains(Objecto) 이 목록에 지정된 요소가 포함되어 있으면 true를 반환합니다. 더 공식적으로는 이 목록에 (o==null?e==null:o.equals(e))와 같은 요소 e가 하나 이상 포함되어 있는 경우에만 true를 반환합니다. 매개변수 c - 이 목록에 존재하는지 테스트할 요소입니다. 반환 값 이 목록에 지정된 요소가 포함되어 있으면 true를 반환합니다. ClassCastException 발생 - 지정된 요소의 유형이 이 목록과 호환되지 않는 경우(선택 사항). 널P

Java의 ArrayList.remove() 함수를 사용하여 ArrayList에서 요소를 제거합니다. Java에서 ArrayList는 요소 집합을 저장하고 작동하는 데 일반적으로 사용되는 컬렉션 클래스입니다. ArrayList 클래스는 컬렉션의 요소를 추가, 삭제, 수정 및 쿼리하는 다양한 메서드를 제공합니다. 가장 자주 사용되는 메서드 중 하나는 ArrayList에서 요소를 제거할 수 있는 Remove()입니다. ArrayList의 Remove() 메소드에는 두 가지 오버로드된 형식이 있습니다.

HashMap 16의 초기 용량이 왜 그렇습니까? ArrayList의 초기화 용량에 대해 이야기할 때 먼저 HashMap의 초기화 용량을 검토해야 합니다. Java8 소스 코드를 예로 들면 HashMap에는 초기화 용량과 로딩 요소라는 두 가지 관련 요소가 있습니다.

Java의 ArrayList.clear() 함수를 사용하여 ArrayList의 요소를 지웁니다. Java 프로그래밍에서 ArrayList는 요소를 동적으로 저장하고 액세스할 수 있는 매우 일반적으로 사용되는 데이터 구조입니다. 그러나 어떤 경우에는 메모리를 재사용하거나 해제하기 위해 ArrayList의 모든 요소를 지워야 할 수도 있습니다. 이때 ArrayList의clear()함수를 사용하면 됩니다. ArrayList.clear()

Java는 ArrayList 클래스의 contain() 함수를 사용하여 요소가 존재하는지 확인합니다. ArrayList는 Java 프로그래밍에서 매우 일반적으로 사용되는 데이터 구조입니다. 이는 데이터 세트를 저장하고 조작하는 유연한 방법을 제공합니다. 단순히 요소를 추가, 삭제 및 액세스하는 것 외에도 ArrayList는 요소가 ArrayList에 존재하는지 확인하는 데 사용되는 contain() 함수와 같은 몇 가지 유용한 메서드도 제공합니다. Contains() 함수는 A입니다.

ArrayList는 ListInterface를 구현하는 JavaCollectionFramework의 클래스입니다. 이는 각 요소를 순차적으로 저장하고 액세스하는 선형 구조입니다. 중복된 요소를 저장할 수 있으며 배열 목록에서 고유한 값을 얻는 데 도움이 될 수 있는 몇 가지 접근 방식이 있습니다.
