inflearn logo
강의

Course

Instructor

Nadocoding's Java Basics - Full Course (20 hours)

Synchronization

동기화

120

hunn1t

6 asked

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번까지 출력할 수 있는건가요?

java 객체지향

Answer 2

0

nadocoding

안녕하세요?

네 맞습니다.

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

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

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

감사합니다.

0

communityai8509

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

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

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

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

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

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

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

자바를 처음 배울 때 이런 고민이 드는 게 정상일까요?

0

136

2

static이 뭐였는지 기억이 안나요 ㅜㅜ

0

110

2

Iterator (알 수 없음) 데이터 삭제 후 초기화 관련 문의

0

70

1

사고력 키우는 법이 어떤게 있나요?

0

91

2

getter setter

0

101

2

섹션9. 66 메소드 오버로딩 시 질문이 있습니다.

0

78

1

안녕하세요 갑자기 프로그램 에러가 떠서 안되네요

0

75

2

변수 이름짓는법

0

114

2

intelli J 실행오류

0

114

2

혹시 이건 수학적 사고가 부족한 걸까요?

0

152

2

영상이 재생이 안됩니다.

0

166

3

이중 반복문 (후반전) 오른쪽으로 치우친 별 쌓기에 질문이 있습니다.

0

114

2

응용이 어렵습니다.

0

203

2

IntelliJ가 보이지 않습니다.

0

182

3

JDK 버전 문의

0

128

2

BlackBox 파일 내에서 메소드 정의

0

136

1

Iterator 문의

0

104

1

코드 순서 문의

0

139

1

클래스 메소드

0

148

2

Quiz_05 관련 질문드립니다 !

0

117

2

다운로드가 안됩니다

0

165

2

다형성

0

118

2

HashMap

0

80

2

재생이 안됩니다ㅠㅠ

0

121

2