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

송민석님의 프로필 이미지
송민석

작성한 질문수

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

Thread 질문

해결된 질문

작성

·

247

0

선생님이 하신거랑 똑같이 했는데 저는 컴파일결과가 사장청소와 직원청소가 섞여서 안나오네요...

 

package chap_12;

import chap_12.clean.CleanThread;

public class _01_Thread {
    public static void main(String[] args) {
        // 하나의 프로세스 (Process)
        // 쓰레드 (Thread)

        // 1 3 5 7 9
        // ---복도---
        // 2 4 6 8 10

        // cleanBySelf();
        CleanThread cleanThread = new CleanThread();
        // cleanThread.run(); // 직원 청소

        cleanThread.start();

        cleanByBoss(); // 사장 청소


    }

    public static void cleanBySelf() {
        System.out.println("-- 혼자 청소 시작 --");
        for (int i = 1; i < 10; i++) {
            System.out.println("(혼자) " + i + "번방 청소 중");
        }
        System.out.println("-- 혼자 청소 끝 --");
    }

    public static void cleanByBoss() {
        System.out.println("-- 사장 청소 시작 --");
        for (int i = 1; i <= 10; i += 2) {
            System.out.println("(사장) " + i + "번방 청소 중");
        }
        System.out.println("-- 사장 청소 끝 --");
    }
}

 

package chap_12.clean;

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)");
        }
        System.out.println("-- 직원 청소 끝 (Thread) --");
    }
}
------------ 결과 ---------------------
-- 사장 청소 시작 --
(사장) 1번방 청소 중
(사장) 3번방 청소 중
(사장) 5번방 청소 중
(사장) 7번방 청소 중
(사장) 9번방 청소 중
-- 사장 청소 끝 --
-- 직원 청소 시작 (Thread) --
(직원) 2번방 청소 중 (Thread)
(직원) 4번방 청소 중 (Thread)
(직원) 6번방 청소 중 (Thread)
(직원) 8번방 청소 중 (Thread)
(직원) 10번방 청소 중 (Thread)
-- 직원 청소 끝 (Thread) --

Process finished with exit code 0

 

답변 1

0

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

안녕하세요?
강의에서 다룬 예제는 너무 빠르게 실행되는 코드라서 쓰레드 처리를 했을 때도 경험하신 것처럼 실행 결과가 뒤섞이지 않은 경우를 종종 볼 수 있답니다. 코드는 잘 적어주셨구요 👍 아마 10번 정도 계속 반복해서 실행하시다보면 조금씩 달라지는 결과가 나올 수도 있는데요.
현재 작성하신 코드에서 두 작업이 동시에 실행되는지를 보다 명확히 확인하려면 임의의 시간만큼 대기하는 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) --");
    }
}

실행해보시면 이번에는 뒤섞인 결과를 확인하실 수 있을 거에요 😊
감사합니다.

송민석님의 프로필 이미지
송민석

작성한 질문수

질문하기