자바 병렬 Exchange 사용 분석

3134 단어 JavaExchanger
클래스 정의
public class Exchanger
그 중에서 V 는 교환 이 필요 한 대상 유형 을 나타 낸다.
상속
java.lang.Object
java.util.concurrent.Exchanger
Exchange 는 Object 에서 직접 계승 합 니 다.
구조 함수
Exchanger() 
exchanger 는 무 참 구조 함 수 를 제공 합 니 다.
두 가지 주요 방법
1.public V exchange(V x) throws InterruptedException
이 방법 이 호출 될 때 현재 스 레 드 는 다른 스 레 드 가 같은 방법 을 호출 할 때 까지 기다 릴 것 입 니 다.다른 스 레 드 가 exchange 를 호출 하면 현재 스 레 드 는 계속 실 행 됩 니 다.
대기 중 에 다른 스 레 드 interrupt 현재 스 레 드 가 있 으 면 Interrupted Exception 을 던 집 니 다.
2.public V exchange(V x, long timeout, TimeUnit unit) throws InterruptedException, TimeoutException
첫 번 째 방법 과 비슷 한 차이 점 은 timeout 시간 이 하나 더 늘 었 다 는 것 이다.timeout 시간 내 에 다른 스 레 드 가 exchange 방법 을 호출 하지 않 으 면 TimeoutException 을 던 집 니 다.
구체 적 인 예
우 리 는 먼저 교환 클래스 를 정의 합 니 다.

@Data
public class CustBook {

    private String name;
}
그리고 두 개의 Runnable 을 정의 하고 run 방법 에서 exchange 방법 을 호출 합 니 다.

@Slf4j
public class ExchangerOne implements Runnable{

    Exchanger<CustBook> ex;

    ExchangerOne(Exchanger<CustBook> ex){
      this.ex=ex;
    }

    @Override
    public void run() {
    CustBook custBook= new CustBook();
        custBook.setName("book one");

        try {
            CustBook exhangeCustBook=ex.exchange(custBook);
            log.info(exhangeCustBook.getName());
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

@Slf4j
public class ExchangerTwo implements Runnable{

    Exchanger<CustBook> ex;

    ExchangerTwo(Exchanger<CustBook> ex){
      this.ex=ex;
    }

    @Override
    public void run() {
    CustBook custBook= new CustBook();
        custBook.setName("book two");

        try {
            CustBook exhangeCustBook=ex.exchange(custBook);
            log.info(exhangeCustBook.getName());
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}
마지막 으로 주 방법 에서 호출:

public class ExchangerUsage {

    public static void main(String[] args) {
        Exchanger<CustBook> exchanger = new Exchanger<>();
        // Starting two threads
        new Thread(new ExchangerOne(exchanger)).start();
        new Thread(new ExchangerTwo(exchanger)).start();
    }
}
우 리 는 결 과 를 보 자.
22:14:09.069 [Thread-1] INFO com.flydean.ExchangerTwo - book one
22:14:09.073 [Thread-0] INFO com.flydean.ExchangerOne - book two
대상 이 교 환 된 것 을 볼 수 있 습 니 다.
결어
exchanger 는 두 스 레 드 에서 대상 을 교환 해 야 할 때 매우 쓰기 좋다.여러분 은 실제 업무 생활 에서 사용 할 수 있 습 니 다.
본문의 예https://github.com/ddean2009/learn-java-concurrency/tree/master/Exchanger
이상 은 자바 병발 exchanger 의 사용 에 대한 상세 한 내용 을 분석 하 는 것 입 니 다.자바 병발 exchanger 의 사용 에 관 한 자 료 는 저희 의 다른 관련 글 을 주목 하 시기 바 랍 니 다!

좋은 웹페이지 즐겨찾기