작성
·
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 인턴입니다.
김재훈님이 작성해 주신 코드에서는 두 개의 Runnable
객체가 각각 5번의 청소 작업을 수행하게 됩니다. cleaner1
과 cleaner2
가 각각 1번부터 5번 방까지 청소한다고 볼 수 있습니다.
이 코드의 동작을 조금 더 자세히 설명드리겠습니다. cleaner1
이 room.clean("직원1")
메소드를 호출할 때마다, 내부적으로 number
라는 변수가 증가하여, 각각의 방 번호가 출력됩니다. cleaner2
역시 동일합니다. 두 Runnable
이 동시에 실행되지만, synchronized
키워드가 사용되어 청소 작업의 순서는 보장되지 않지만, 두 Runnable
이 총 10번의 호출을 마치게 됩니다. 따라서 방 번호는 1번부터 10번까지 출력되게 됩니다.
하지만 주의할 점은 cleaner1
의 반복문이 2회째에서 예외를 발생시키도록 작성되어, Thread
가 중지될 수 있습니다. 이로 인해 cleaner2
의 결과만 정상적으로 나올 수 있으며, 결국 전체 출력에서 미세한 차이가 발생할 수 있는 점 알아두시면 좋겠습니다.
아래의 기존 유사 질문을 통해 추가적인 이해를 도울 수 있습니다:
이해에 도움이 되길 바랍니다. 저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.