인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

김재훈님의 프로필 이미지

작성한 질문수

나도코딩의 자바 기본편 - 풀코스 (20시간)

동기화

동기화

작성

·

47

0

 동기화 강의 중

Room room = new Room();

Runnable cleaner1 = new Runnable() {
    @Override
    public void run() {
        System.out.println("-- 직원1 청소 시작 --");
        for (int i = 1; i <= 5; i++) {
            room.clean("직원1");

            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }

            if (i == 2) {
                throw new RuntimeException("못해먹겠다!!");
            }
        }
        System.out.println("-- 직원1 청소 끝 --");
    }
};

Runnable cleaner2 = () -> {
    System.out.println("-- 직원2 청소 시작 --");
    for (int i = 1; i <= 5; i++) {
        room.clean("직원2");
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }
    }
    System.out.println("-- 직원2 청소 끝 --");
};

Thread cleanerThread1 = new Thread(cleaner1);
Thread cleanerThread2 = new Thread(cleaner2);

cleanerThread1.start();
cleanerThread2.start();

수업에 사용한 위 코드가 10번방까지 출력이 되는 것은, for 반복문으로 1~5 까지 5개씩의 반복을 두 개 만들었기 때문에 자연적으로 10번까지 출력할 수 있는건가요?

답변 2

0

나도코딩님의 프로필 이미지
나도코딩
지식공유자

안녕하세요?

네 맞습니다.

문의글에 남겨주신 코드는 아래와 같이 예외를 발생시키는 부분이 있기 때문에 도중에 문제가 발생하기는 하지만 이 부분이 없다면 말씀주신 것처럼 for 반복문으로 1-5 까지 5개씩의 반복을 2개 만들었기 때문에 총합 10개의 방을 청소하게 됩니다.

if (i == 2) {
    throw new RuntimeException("못해먹겠다!!");
}

연습삼아 for 반복문 내 조건을 5가 아닌 다른 값으로 바꿔보시면 그에 맞게 증가하는 것을 확인하실 수 있을 거에요 🙂 가령 8로 설정하게 되면 2명이 8개의 방을 청소하게 되므로 16까지 출력이 될 것입니다.

감사합니다.

0

인프런 AI 인턴님의 프로필 이미지

안녕하세요, 인프런 AI 인턴입니다.

김재훈님이 작성해 주신 코드에서는 두 개의 Runnable 객체가 각각 5번의 청소 작업을 수행하게 됩니다. cleaner1cleaner2가 각각 1번부터 5번 방까지 청소한다고 볼 수 있습니다.

이 코드의 동작을 조금 더 자세히 설명드리겠습니다. cleaner1room.clean("직원1") 메소드를 호출할 때마다, 내부적으로 number라는 변수가 증가하여, 각각의 방 번호가 출력됩니다. cleaner2 역시 동일합니다. 두 Runnable이 동시에 실행되지만, synchronized 키워드가 사용되어 청소 작업의 순서는 보장되지 않지만, 두 Runnable이 총 10번의 호출을 마치게 됩니다. 따라서 방 번호는 1번부터 10번까지 출력되게 됩니다.

하지만 주의할 점은 cleaner1의 반복문이 2회째에서 예외를 발생시키도록 작성되어, Thread가 중지될 수 있습니다. 이로 인해 cleaner2의 결과만 정상적으로 나올 수 있으며, 결국 전체 출력에서 미세한 차이가 발생할 수 있는 점 알아두시면 좋겠습니다.

아래의 기존 유사 질문을 통해 추가적인 이해를 도울 수 있습니다:

  1. “Thread가 동시에 실행이 안됩니다.”
  2. “동기화강의내용에서질문에요”

이해에 도움이 되길 바랍니다. 저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.