> Java > Java베이스 > 본문

Java에는 여러 가지 스레드 상태가 있습니다.

青灯夜游
풀어 주다: 2022-11-24 16:03:03
원래의
14228명이 탐색했습니다.

Java에는 초기(NEW), 실행 중(RUNNABLE), 차단됨(BLOCKED), 대기 중(WAITING), 시간 초과 대기(TIMED_WAITING) 및 종료됨(TERMINATED)의 6가지 스레드 상태가 있습니다. new 키워드를 사용하여 새 스레드를 생성했지만 start() 메서드가 호출되지 않았습니다. 스레드가 차단된 상태는 스레드가 모니터 잠금을 기다리고 있으며 상태에 갇혀 있음을 나타냅니다. 대기 상태에 들어간 스레드는 다른 스레드가 결정을 내릴 때까지 기다려야 합니다. 일부 특정 작업(알림 또는 인터럽트).

Java에는 여러 가지 스레드 상태가 있습니다.

이 튜토리얼의 운영 환경: windows7 시스템, java8 버전, Dell G3 컴퓨터.

Java스레드의 상태는 6 유형으로 나뉩니다.

1. Initial(NEW): 새 스레드 객체가 생성되었지만 start() 메서드가 생성되지 않았습니다. 아직 전화하지 않았습니다.
2. 실행(RUNNABLE): Java 스레드에서는 준비 및 실행의 두 가지 상태를 일반적으로 "실행 중"이라고 합니다.
스레드 객체가 생성된 후 다른 스레드(예: 메인 스레드)는 해당 객체의 start() 메서드를 호출합니다. 이 상태의 스레드는 실행 가능한 스레드 풀에 위치하며 스레드 스케줄링에 의해 선택되어 CPU 사용 권한을 얻기를 기다리고 있습니다. 이때는 준비 상태입니다. 준비 상태의 스레드는 CPU 타임 슬라이스를 얻은 후 실행됩니다.
3. BLOCKED: 스레드가 잠금 장치에 차단되었음을 나타냅니다.
4. Waiting: 이 상태에 진입한 스레드는 다른 스레드가 특정 작업(알림 또는 인터럽트)을 수행할 때까지 기다려야 합니다.
5. 타임아웃 대기(TIMED_WAITING): 이 상태는 WAITING과는 다르며, 지정된 시간이 지나면 스스로 돌아올 수 있습니다.
6. TERMINATED: 스레드 실행이 완료되었음을 나타냅니다.

이 6가지 상태는 Thread 클래스의 State 열거에 정의되어 있습니다. 일대일 대응에 대한 소스 코드를 볼 수 있습니다.

1. 스레드 상태 다이어그램

Java에는 여러 가지 스레드 상태가 있습니다.

2. 상태 상세 설명

1. 초기 상태(NEW)

Runnable 인터페이스를 구현하고 Thread를 상속하면 새로운 인스턴스가 나올 때 스레드 클래스를 얻을 수 있습니다. 스레드는 초기 상태에 들어갑니다.

2.1. 준비 상태(READY of RUNNABLE)

  • 준비 상태는 스케줄러가 선택하지 않으면 항상 Ready 상태에 있음을 의미합니다.

  • 스레드의 start() 메소드를 호출하면 이 스레드는 Ready 상태로 들어갑니다.

  • 현재 스레드의 sleep() 메소드가 종료되고, 다른 스레드의 Join() 메소드가 종료됩니다. 사용자 입력이 완료된 후 스레드는 객체 잠금을 획득하고 이 스레드도 Ready에 진입합니다. 상태.

  • 현재 스레드 시간 조각이 모두 사용되고 현재 스레드의 Yield() 메서드가 호출되며 현재 스레드는 Ready 상태에 들어갑니다.

  • 잠금 풀의 스레드는 개체 잠금을 획득한 후 Ready 상태로 들어갑니다.

2.2. 실행 상태(RUNNABLE of RUNNING)

스레드 스케줄러가 실행 가능 풀에서 스레드를 현재 스레드로 선택할 때의 스레드 상태입니다. 이는 스레드가 실행 상태로 들어가는 유일한 방법이기도 합니다.

3. 차단된 상태(BLOCKED)

차단된 상태는 동기화된 키워드로 수정된 메소드 또는 코드 블록(잠금 획득)에 진입할 때 스레드가 차단되는 상태입니다.

4. 대기(WAITING)

이 상태의 스레드에는 CPU 실행 시간이 할당되지 않습니다. 명시적으로 활성화될 때까지 기다려야 합니다. 그렇지 않으면 무기한 대기 상태가 됩니다.

5. 타임아웃 대기(TIMED_WAITING)

이 상태의 스레드에는 CPU 실행 시간이 할당되지 않지만 다른 스레드에 의해 명시적으로 깨어나기 위해 무기한 기다릴 필요는 없습니다. .

6. TERMINATED

  • 스레드의 run() 메소드가 완료되거나 메인 스레드의 main() 메소드가 완료되면 종료된 것으로 간주합니다. 이 스레드 개체는 활성 상태일 수 있지만 더 이상 별도로 실행되는 스레드가 아닙니다. 스레드가 종료되면 다시 되살릴 수 없습니다.

  • 종료된 스레드에서 start() 메서드를 호출하면 java.lang.IllegalThreadStateException 예외가 발생합니다.

3. 대기 대기열

  • obj의 wait() 및 inform() 메서드를 호출하기 전에 obj 잠금을 얻어야 합니다. 즉, 동기화된(obj) 코드 세그먼트에 작성되어야 함을 의미합니다.
  • 대기 대기열과 관련된 단계 및 다이어그램

Java에는 여러 가지 스레드 상태가 있습니다.

  • 스레드 1은 객체 A의 잠금을 획득하고 객체 A를 사용하고 있습니다.

  • 스레드 1은 객체 A의 wait() 메서드를 호출합니다.

  • 스레드 1은 객체 A의 잠금을 해제하고 즉시 대기 대기열에 들어갑니다.

  • 잠금 풀에 있는 개체는 개체 A의 잠금을 놓고 경쟁합니다.

  • 스레드 5는 객체 A의 잠금을 획득하고 동기화된 블록에 들어가 객체 A를 사용합니다.

  • Thread 5는 객체 A의 informAll() 메서드를 호출하고 모든 스레드를 깨우며 모든 스레드가 동기화 대기열에 들어갑니다. 스레드 5가 객체 A의 inform() 메서드를 호출하면 스레드가 깨어나게 되며 깨어난 스레드는 동기화 대기열에 들어갈 것입니다.

  • notifyAll() 메서드가 동기화되어 종료되고 스레드 5가 객체 A의 잠금을 해제합니다.

  • 동기화 대기열의 스레드는 개체 잠금을 놓고 경쟁하지만 스레드 1이 개체 잠금을 언제 확보할 수 있는지 알 수 없습니다.

4. 동기화 대기열 상태

  • 현재 스레드가 개체 A의 동기화 메서드를 호출하려고 할 때 개체 A의 잠금이 다른 스레드에 의해 점유된 것을 발견합니다. 동기화 대기열. 간단히 말해서 동기화 대기열은 객체 잠금을 놓고 경쟁하려는 스레드로 채워져 있습니다.
  • 스레드 1이 다른 스레드 2에 의해 깨어나면 스레드 1은 동기화 대기열에 들어가 객체 잠금을 놓고 경쟁합니다.
  • 동기화 큐는 동기화된 환경에만 존재하는 개념입니다. 하나의 개체는 동기화 큐에 해당합니다.
  • 스레드 대기 시간이 끝나거나 통지/notifyAll에 의해 깨어난 후, 잠금을 획득하기 위해 동기화 큐에 들어가고, 잠금을 획득하면 RUNNABLE 상태로 들어가고, 그렇지 않으면 BLOCKED 상태로 들어가게 됩니다. 잠금을 얻을 때까지 기다리십시오.

5. 여러 메소드 비교

  • Thread.sleep(long millis), 이 메소드는 현재 스레드에서 호출되어야 합니다. 현재 스레드는 TIMED_WAITING 상태에 들어가지만 이후에는 개체 잠금을 해제하지 않습니다. millis이면 스레드가 자동으로 깨어나서 준비 상태로 들어갑니다. 역할: 다른 스레드에 실행할 기회를 제공하는 가장 좋은 방법입니다.

  • Thread.yield(), 이 메서드는 현재 스레드에서 호출되어야 합니다. 현재 스레드는 획득한 CPU 타임 슬라이스를 포기하지만 잠금 리소스를 해제하지 않고 실행 상태에서 준비 상태로 변경됩니다. OS가 스레드를 다시 선택할 수 있도록 허용합니다. 기능: 동일한 우선순위를 가진 스레드를 차례로 실행하지만, 차례로 실행된다는 보장은 없습니다. 실제로는 항복 스레드가 스레드 스케줄러에 의해 다시 선택될 수 있으므로 항복()이 항복 목적을 달성한다는 보장이 없습니다. Thread.yield()는 차단을 유발하지 않습니다. 이 메서드는 사용자가 일시 중지할 기간을 지정할 수 없다는 점을 제외하면 sleep()과 유사합니다.

  • thread.join()/thread.join(long millis), 현재 스레드가 다른 스레드 t의 조인 메서드를 호출하고, 현재 스레드가 WAITING/TIMED_WAITING 상태에 들어가고, 현재 스레드가 해제되지 않습니다. 보유된 객체 잠금. 스레드 t가 실행을 완료하거나 밀리 시간이 만료되면 현재 스레드는 일반적으로 RUNNABLE 상태로 들어가고 BLOCKED 상태로 들어갈 수도 있습니다(조인은 대기 기반으로 구현되기 때문).

  • obj.wait(), 현재 스레드가 개체의 wait() 메서드를 호출하면 현재 스레드가 개체 잠금을 해제하고 대기 대기열에 들어갑니다. 알림()/notifyAll()을 사용하여 깨우거나 대기(긴 시간 제한)를 사용하여 제한 시간이 만료되면 자동으로 깨울 수 있습니다.

  • obj.notify()는 이 개체 모니터를 기다리고 있는 단일 스레드를 깨우며 선택은 임의적입니다. informAll()은 이 객체 모니터에서 대기 중인 모든 스레드를 깨웁니다.

  • LockSupport.park()/LockSupport.parkNanos(long nanos),LockSupport.parkUntil(긴 기한), 현재 스레드는 WAITING/TIMED_WAITING 상태로 들어갑니다. wait 메소드에 비해 스레드는 잠금을 획득하지 않고도 WAITING/TIMED_WAITING 상태에 진입할 수 있으며, LockSupport.unpark(Thread 스레드)를 통해 깨어나야 합니다.

더 많은 프로그래밍 관련 지식을 보려면 프로그래밍 교육을 방문하세요! !

위 내용은 Java에는 여러 가지 스레드 상태가 있습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!