inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

김영한의 실전 자바 - 고급 1편, 멀티스레드와 동시성

join - 시작

JoinMainV0에 관한 질문

163

lgh8079

작성한 질문수 35

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]

image.png

이런 식으로 출력이 되는데 코드에 어떤 문제가 있는 건가요?? Start 작업 시작 작업 시작 End 작업 완료 작업 완료 이런 식으로 출력 값이 떠야 하는데 어떤 문제가 있는 건가요?

java 객체지향 동시성 multithread thread

답변 2

1

dev.rudevico

  1. 멀티스레드는 작업의 순서를 보장하지 않는다.

  2. lgh8079님과 같이 출력된 이유를 굳이 생각해보자면 다음과 같은 시나리오로 유추할 수 있습니다.

thread1.start()를 호출 
-> 작업1) 객체로만 존재하던 thread1에게 실제로 물리적인 스택 공간을 할당하는 작업, 대기 큐에 넣는 작업 등을 수행.
-> 작업2) 위 작업 등을 모두 수행하면 그제서야 run() 메서드를 호출 => "작업 시작"이 출력

따라서 thread1.start()를 호출함으로 인해 작업1)이 수행되는 동안에 main 스레드는 다음 스택 프레임인 log("End")를 수행하고/완료합니다.
// ㄴ 콘솔에 [        main] End 출력
그 뒤에야 thread1의 작업1)이 완료되고, thread의 작업2)를 수행하게 됩니다.
// ㄴ 콘솔에 [    thread-1] 작업 시작 출력

다시 정리해서 말하자면, thread1.start()를 호출한다고 해서 thread1이 곧바로 run()을 호출하는 것이 아니고, thread1에 물리적 스택 메모리를 할당하는 등의 사전 작업이 선행되어야 하고 그 동안 main 스레드는 이와 무관하게 본인의 할 일(log("End") 호출)을 계속 수행하기 때문에 화면과 같이 출력된 것이라고 유추할 수 있습니다.


1

dev.rudevico

또한 멀티 스레드는 작업 순서를 보장하기 않기 때문에, 경우에 따라서는 thread1을 위한 사전 작업(메모리 할당 등)과 run() 메서드 호출의 우선순위가 이전보다 높게 책정되거나 컴퓨터 성능 차이에 의해 매우 빠르게 수행되거나 하는 시나리오 하에서는 main 스레드가 log("End")를 호출하기 전에 thread1의 작업이 먼저 수행되어 다음과 같이 출력될 수도 있습니다.

// 또 다른 시나리오 1.
[        main] Start
[    thread-1] 작업 시작
[    thread-1] 작업 종료
[        main] End

// 또 다른 시나리오 2.
[        main] Start
[    thread-1] 작업 시작
[        main] End
[    thread-1] 작업 종료

0

y2gcoder

안녕하세요. lgh8079님, 공식 서포터즈 y2gcoder입니다.

JoinMainV0 을 강의 코드와 동일하게 구성하셨다면 정상적인 출력인 것으로 보입니다.

강의자료에도 메인 쓰레드의 Start, End 후 thread-1과 thread-2의 작업이 발생하고 있습니다!

image.png

 

감사합니다.

모니터와 synchronized, ReentrantLock, 원자적연산 CAS관련해서 추가적으로 더 깊게 공부했는데 제가 이해한 것이 맞나요??

0

85

1

Future cancel기능을 사용했지만 interrupt가 발생하지 않을 때 어떻게 처리해야하나요?

0

73

2

2.스레드 생성과 실행 - 17P 그림 문의

0

74

2

자바 동시성 현업에서 사용예시가 궁금합니다

0

136

1

ReentrantLock 동작 원리에 대한 질문입니다.

0

84

1

synchronized 대신 join 을 사용하여 순서를 보장할 경우 해법이 아닌가요?

0

94

2

메모리 가시성 문제 질문

0

72

1

Future4-이유 질문

0

64

1

오타 제보

0

77

2

runnable 질문

0

95

2

자바가 아닌 다른 언어에서도

0

112

1

메모리 가시성 문제가 발생하는 이유

0

125

1

데몬스레드가 어떨 때 사용이 되는지 궁금합니다.

0

78

1

Future.cancel() 취소를 사용하는 예가 궁금합니다.

0

84

1

synchronized 와 인스턴스의 lock

0

91

2

synchronized 키워드만으로 메모리 가시성이 해결되는 이유가 궁급합니다.

0

63

1

[스레드 풀과 Executor 프레임워크1][문제와 풀이] `log("일부 작업이 실패했습니다.");` 실행되는 경우가 있을까요?

0

59

1

원자적 연산이 멀티스레드 상황에서 안전한 이유를 제대로 이해했는지 확인 부탁드립니다

0

67

2

자바 고급 1,2,3편 같이 진행해도 문제없나요

0

77

2

CPU 캐시 때문에도 잔액이 200원이 될 수 있나요?

0

105

2

synchronized 메서드와 join 관련 질문이 있습니다.

0

69

2

섹션 14. 115번 강의 내용 질문

0

83

2

교안에 있는 7페이지 데이터 영역

0

51

1

Executor 스레드 풀 관리 질문

0

108

2