자바 다 중 스 레 드 yield 심득 공유

1.Thread.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 시간 을 빼 앗 아 실 행 됩 니 다.

좋은 웹페이지 즐겨찾기