스레드 강의에서 코드를 동일하게 작성했는데 결과가 다릅니다.
강의에서는 청소가 번갈아가면서 나오는데 여러번 실행해도 한 번도 번갈아가면서
나오지 않습니다..ㅠ
-- 사장 청소 시작 --
-- 직원 청소 시작 (Thread) --
(사장)1 번방 청소 중
(사장)3 번방 청소 중
(사장)5 번방 청소 중
(사장)7 번방 청소 중
(사장)9 번방 청소 중
-- 사장 청소 끝 --
(직원)2 번방 청소 중 (Thread)
(직원)4 번방 청소 중 (Thread)
(직원)6 번방 청소 중 (Thread)
(직원)8 번방 청소 중 (Thread)
(직원)10 번방 청소 중 (Thread)
-- 직원 청소 끝 (Thread) --
-- 사장 청소 시작 --
-- 직원 청소 시작 (Thread) --
(직원)2 번방 청소 중 (Thread)
(직원)4 번방 청소 중 (Thread)
(직원)6 번방 청소 중 (Thread)
(직원)8 번방 청소 중 (Thread)
(직원)10 번방 청소 중 (Thread)
-- 직원 청소 끝 (Thread) --
(사장)1 번방 청소 중
(사장)3 번방 청소 중
(사장)5 번방 청소 중
(사장)7 번방 청소 중
(사장)9 번방 청소 중
-- 사장 청소 끝 --
이 두가지만 나오는데
다른 이유가 있을까요..?
답변 1
0
안녕하세요?
여러 번 돌렸음에도 불구하고 순서가 섞이지 않는다면 start() 가 아닌 run() 메소드를 직접 호출하신 것은 아닌지 확인이 필요합니다. 또는 코드를 잘 적어주셨다면 혹시 모르니 임의의 시간만큼 대기하는 Thread.sleep(ms) 를 넣어보시면 섞인 결과를 확인하실 수도 있어요.
대기하는 부분은 작성하신 코드에서 아래와 같이 반복문 내에 각각 수정해주시면 되며, 이는 사장 또는 직원이 하나의 방을 청소할 때마다 500 ms, 즉 0.5 초씩 대기하게 됩니다. 주석 처리된 부분을 참고해주세요.
...
public static void cleanByBoss() {
System.out.println("-- 사장 청소 시작 --");
for (int i = 1; i <= 10; i += 2) {
System.out.println("(사장) " + i + "번방 청소 중");
//////////// 코드 추가된 부분 ///////////////
try {
Thread.sleep(500);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
//////////// 코드 추가된 부분 ///////////////
}
System.out.println("-- 사장 청소 끝 --");
}public class CleanThread extends Thread {
public void run() {
System.out.println("-- 직원 청소 시작 (Thread) --");
for (int i = 2; i <= 10; i += 2) {
System.out.println("(직원) " + i + "번방 청소 중 (Thread)");
//////////// 코드 추가된 부분 ///////////////
try {
Thread.sleep(500);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
//////////// 코드 추가된 부분 ///////////////
}
System.out.println("-- 직원 청소 끝 (Thread) --");
}
}실행해보시면 이번에는 뒤섞인 결과를 확인하실 수 있을 거에요 😊 그럼에도 불구하고 잘 되지 않는다면 코드와 함께 다시 질문을 남겨주시면 도움드리겠습니다.
감사합니다.
자바를 처음 배울 때 이런 고민이 드는 게 정상일까요?
1
146
2
static이 뭐였는지 기억이 안나요 ㅜㅜ
0
119
2
Iterator (알 수 없음) 데이터 삭제 후 초기화 관련 문의
0
72
1
사고력 키우는 법이 어떤게 있나요?
0
94
2
getter setter
0
103
2
섹션9. 66 메소드 오버로딩 시 질문이 있습니다.
0
80
1
안녕하세요 갑자기 프로그램 에러가 떠서 안되네요
0
76
2
변수 이름짓는법
0
114
2
intelli J 실행오류
0
115
2
혹시 이건 수학적 사고가 부족한 걸까요?
0
152
2
영상이 재생이 안됩니다.
0
167
3
이중 반복문 (후반전) 오른쪽으로 치우친 별 쌓기에 질문이 있습니다.
0
117
2
응용이 어렵습니다.
0
206
2
IntelliJ가 보이지 않습니다.
0
187
3
JDK 버전 문의
0
130
2
BlackBox 파일 내에서 메소드 정의
0
136
1
동기화
0
122
2
Iterator 문의
0
105
1
코드 순서 문의
0
143
1
클래스 메소드
0
150
2
Quiz_05 관련 질문드립니다 !
0
118
2
다운로드가 안됩니다
0
165
2
다형성
0
120
2
HashMap
0
80
2





