자바 다 중 스 레 드 yield 심득 공유
현재 스 레 드 를 실행 상태(실행 상태)에서 실행 가능 상태(준비 상태)로 바 꿉 니 다.cpu 는 여러 실행 가능 한 상태 에서 선택 합 니 다.즉,현재,방금 그 스 레 드 는 다시 실 행 될 수 있 습 니 다.반드시 다른 스 레 드 를 실행 할 것 이 라 고 말 하 는 것 이 아니 라 다음 스 레 드 에서 실 행 될 수 없습니다.
자바 스 레 드 에는 Thread.yield()방법 이 있 습 니 다.많은 사람들 이 스 레 드 로 번역 하여 양보 합 니 다.말 그대로 하나의 스 레 드 가 이 방법 을 사용 하면 자신의 CPU 가 실행 하 는 시간 을 빼 고 자신 이나 다른 스 레 드 를 실행 하 게 된다 는 것 이다.
예 를 들 어 지금 많은 사람들 이 줄 을 서서 화장실 에 가 고 있 습 니 다.가까스로 이 사람 이 화장실 에 갈 차례 가 되 었 습 니 다.갑자기 이 사람 이 말 했 습 니 다."저 는 여러분 과 경 기 를 해 보 겠 습 니 다.누가 먼저 화장실 을 빼 앗 는 지 보 겠 습 니 다!"그리고 모든 사람들 이 같은 라인 에서 화장실 로 달 려 갔 는데 다른 사람 이 뺏 었 을 수도 있 고 자기가 뺏 었 을 수도 있 었 다.우 리 는 스 레 드 에 우선 순위 가 있다 는 것 도 알 고 있다.그러면 우선권 을 가 진 이 사람들 이 화장실 의 위 치 를 반드시 빼 앗 을 수 있 을 까?꼭 그렇지 는 않 습 니 다.그들 은 확률 이 높 을 뿐 특권 없 이 빼 앗 을 수도 있 습 니 다.
예:
package com.yield;
public class YieldTest extends Thread {
public YieldTest(String name) {
super(name);
}
@Override
public void run() {
for (int i = 1; i <= 50; i++) {
System.out.println("" + this.getName() + "-----" + i);
// i 30 , CPU , ( )
if (i == 30) {
this.yield();
}
}
}
public static void main(String[] args) {
YieldTest yt1 = new YieldTest(" ");
YieldTest yt2 = new YieldTest(" ");
yt1.start();
yt2.start();
}
}
실행 결과:첫 번 째 상황:이사(스 레 드)가 30 까지 실 행 될 때 CPU 시간 이 떨 어 집 니 다.이때 장 삼(스 레 드)은 CPU 시간 을 빼 앗 아 실 행 됩 니 다.
두 번 째 상황:이사(스 레 드)가 30 까지 실 행 될 때 CPU 시간 이 떨 어 집 니 다.이때 이사(스 레 드)는 CPU 시간 을 빼 앗 아 실 행 됩 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 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에 따라 라이센스가 부여됩니다.