자바의 스레드 양보 yield () 와 스레드 휴면 sleep () 방법

7280 단어 Java라인
스레드 양보: yield()
yield()의 역할은 양보이다.이것은 현재 스레드가'실행 상태'에서'준비 상태'로 들어가서 같은 우선순위를 가진 다른 대기 스레드가 실행권을 얻도록 할 수 있다.단, 현재 스레드가 yield()를 호출한 후에 같은 우선순위를 가진 다른 스레드가 반드시 집행권을 얻을 수 있음을 보장할 수 없다.현재 라인이 다시 "운행 상태"로 들어가 계속 운행할 수도 있습니다!
예:

class ThreadA extends Thread{
  public ThreadA(String name){ 
    super(name); 
  } 
  public synchronized void run(){ 
    for(int i=0; i <10; i++){ 
      System.out.printf("%s [%d]:%d
", this.getName(), this.getPriority(), i); // i 4 , yield if (i%4 == 0) Thread.yield(); } } } public class YieldTest{ public static void main(String[] args){ ThreadA t1 = new ThreadA("t1"); ThreadA t2 = new ThreadA("t2"); t1.start(); t2.start(); } }
실행 결과:

t1 [5]:0
t2 [5]:0
t1 [5]:1
t1 [5]:2
t1 [5]:3
t1 [5]:4
t1 [5]:5
t1 [5]:6
t1 [5]:7
t1 [5]:8
t1 [5]:9
t2 [5]:1
t2 [5]:2
t2 [5]:3
t2 [5]:4
t2 [5]:5
t2 [5]:6
t2 [5]:7
t2 [5]:8
t2 [5]:9
결과 설명:
'선정 t1'은 4정수가 될 때'선정 t2'로 전환되지 않습니다.이것은 yield()가 라인을'운행상태'에서'준비상태'로 진입시킬 수 있음을 나타낸다.그러나 다른 스레드가 현재 yield () 를 호출하는 스레드와 같은 우선순위를 가지더라도 CPU 실행권을 다른 스레드에 가져오는 것은 아닙니다.
yield()와wait()의 비교:
우리는wait()의 작용이 현재 라인을'운행상태'에서'대기(막힘)상태'로 진입하는 동시에 동기화 자물쇠를 방출하는 것을 알고 있다.한편, yield () 의 역할은 양보입니다. 이것은 현재 라인을 실행 상태에서 벗어나게 합니다.그것들의 차이점은 다음과 같다.
(1)wait () 는 "운행 상태"에서 "기다리기 (막힘) 상태"로 라인을 진입시키는 것이지, yield () 는 "운행 상태"에서 "준비 상태"로 라인을 진입시키는 것이 아니다.
(2)wait () 는 회선이 가지고 있는 대상의 동기화 자물쇠를 방출하고, yield () 방법은 자물쇠를 방출하지 않습니다.
다음 예제에서는 yield () 가 잠금을 해제하지 않음을 보여 줍니다.

public class YieldLockTest{ 

  private static Object obj = new Object();

  public static void main(String[] args){ 
    ThreadA t1 = new ThreadA("t1"); 
    ThreadA t2 = new ThreadA("t2"); 
    t1.start(); 
    t2.start();
  } 

  static class ThreadA extends Thread{
    public ThreadA(String name){ 
      super(name); 
    } 
    public void run(){ 
      //  obj 
      synchronized (obj) {
        for(int i=0; i <10; i++){ 
          System.out.printf("%s [%d]:%d
", this.getName(), this.getPriority(), i); // i 4 , yield if (i%4 == 0) Thread.yield(); } } } } }
실행 결과:

t1 [5]:0
t1 [5]:1
t1 [5]:2
t1 [5]:3
t1 [5]:4
t1 [5]:5
t1 [5]:6
t1 [5]:7
t1 [5]:8
t1 [5]:9
t2 [5]:0
t2 [5]:1
t2 [5]:2
t2 [5]:3
t2 [5]:4
t2 [5]:5
t2 [5]:6
t2 [5]:7
t2 [5]:8
t2 [5]:9
결과 설명:
메인 라인main에서 두 개의 라인 t1과 t2가 시작되었습니다.t1과 t2는run()에서 같은 대상의 동기화 자물쇠, 즉synchronized(obj)를 인용합니다.T1이 실행되는 동안 Thread를 호출합니다.yield();단, t2는 cpu 집행권을 얻지 못합니다.왜냐하면, t1은 "obj가 가지고 있는 동기화 자물쇠"를 방출하지 않았기 때문이다!
스레드 휴면: sleep ()
sleep()은 Thread에 정의됩니다.자바 중.
sleep () 의 역할은 현재 라인을 휴면시키는 것입니다. 즉, 현재 라인은'실행 상태'에서'휴면 (막힘) 상태'로 진입합니다.sleep () 는 휴면 시간을 지정하고 라인의 휴면 시간은/과 같습니다.루틴이 다시 깨어날 때,'막힌 상태'에서'준비 상태'로 바뀌어 cpu의 스케줄링이 실행되기를 기다립니다.
예:

class ThreadA extends Thread{
  public ThreadA(String name){ 
    super(name); 
  } 
  public synchronized void run() { 
    try {
      for(int i=0; i <10; i++){ 
        System.out.printf("%s: %d
", this.getName(), i); // i 4 , 100 if (i%4 == 0) Thread.sleep(100); } } catch (InterruptedException e) { e.printStackTrace(); } } } public class SleepTest{ public static void main(String[] args){ ThreadA t1 = new ThreadA("t1"); t1.start(); } }
실행 결과:

t1: 0
t1: 1
t1: 2
t1: 3
t1: 4
t1: 5
t1: 6
t1: 7
t1: 8
t1: 9
결과 설명:
프로그램이 비교적 간단합니다. 메인 라인main에서 라인 t1을 시작합니다.t1이 시작되면 t1의 계산 i가 4로 정리될 때 t1은 Thread를 통과합니다.sleep(100)는 100밀리초 동안 휴면합니다.
sleep () 와wait () 의 비교:
우리는wait()의 작용이 현재 라인을'운행상태'에서'대기(막힘)상태'로 진입하는 동시에 동기화 자물쇠를 방출하는 것을 알고 있다.sleep () 의 역할은 현재 라인이'운행 상태'에서'휴면 (막힘) 상태'로 들어가는 것이다.
그러나wait()는 대상의 동기화 자물쇠를 방출하고sleep()는 자물쇠를 방출하지 않습니다.
다음은 예시를 통해 sleep () 가 자물쇠를 풀지 않는다는 것을 보여 줍니다.

public class SleepLockTest{ 

  private static Object obj = new Object();

  public static void main(String[] args){ 
    ThreadA t1 = new ThreadA("t1"); 
    ThreadA t2 = new ThreadA("t2"); 
    t1.start(); 
    t2.start();
  } 

  static class ThreadA extends Thread{
    public ThreadA(String name){ 
      super(name); 
    } 
    public void run(){ 
      //  obj 
      synchronized (obj) {
        try {
          for(int i=0; i <10; i++){ 
            System.out.printf("%s: %d
", this.getName(), i); // i 4 , 100 if (i%4 == 0) Thread.sleep(100); } } catch (InterruptedException e) { e.printStackTrace(); } } } } }
실행 결과:

t1: 0
t1: 1
t1: 2
t1: 3
t1: 4
t1: 5
t1: 6
t1: 7
t1: 8
t1: 9
t2: 0
t2: 1
t2: 2
t2: 3
t2: 4
t2: 5
t2: 6
t2: 7
t2: 8
t2: 9
결과 설명:
메인 라인main에서 두 개의 라인 t1과 t2가 시작되었습니다.t1과 t2는run()에서 같은 대상의 동기화 자물쇠, 즉synchronized(obj)를 인용합니다.T1이 실행되는 동안 Thread를 호출합니다.sleep(100);단, t2는 cpu 집행권을 얻지 못합니다.왜냐하면, t1은 "obj가 가지고 있는 동기화 자물쇠"를 방출하지 않았기 때문이다!
주의, 만약synchronized (obj) 를 주석한 후에 이 프로그램을 다시 실행한다면, t1과 t2는 서로 전환할 수 있습니다.다음은 주석 조정 synchronized(obj) 이후의 원본 코드입니다.

public class SleepLockTest{ 

  private static Object obj = new Object();

  public static void main(String[] args){ 
    ThreadA t1 = new ThreadA("t1"); 
    ThreadA t2 = new ThreadA("t2"); 
    t1.start(); 
    t2.start();
  } 

  static class ThreadA extends Thread{
    public ThreadA(String name){ 
      super(name); 
    } 
    public void run(){ 
      //  obj 
//      synchronized (obj) {
        try {
          for(int i=0; i <10; i++){ 
            System.out.printf("%s: %d
", this.getName(), i); // i 4 , 100 if (i%4 == 0) Thread.sleep(100); } } catch (InterruptedException e) { e.printStackTrace(); } // } } } }

좋은 웹페이지 즐겨찾기