inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

스레드와 스케줄링

스케줄링에 대한 질문입니다.

130

jjin

작성한 질문수 26

0

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

[질문 내용]
프로세스 스케줄링과 스레드 스케줄링의 차이에 대해 궁금합니다. 두가지는 동일한 개념인가요? 1개의 CPU 코어는 한번에 하나의 스레드만 실행할 수 있나요?

java 객체지향 동시성 multithread thread

답변 2

1

dev.rudevico

  1. 1개의 CPU 코어는 한 번에 하나의 스레드만 실행할 수 있습니다. 다만 시분할을 통해 마치 여러 개의 스레드가 동시에 처리되는 것처럼 느낄 정도로 여러 스레드가 빠르게/조금씩/번갈아가며 처리됩니다.

  2. 프로세스 스케쥴링과 스레드 스케쥴링은 다릅니다.

    1. 두 개의 프로세스를 가정하겠습니다. 프로세스1=운영체제(윈도우), 프로세스2=인터넷브라우저(유튜브)

    2. 프로세스끼리 우선순위를 비교한다면 당연하게도 컴퓨터 실행의 기본이 되는 운영체제 프로세스가 우선적인 순위를 가집니다. 운영체제가 제대로 실행되지 않고 있다면 인터넷 브라우저는 당연히 실행되지 못하기 때문에 우선적으로 운영체제의 제대로 된 실행을 보장해 주어야 합니다.

    3. 운영체제 내부에서 본다면 마우스 클릭, 키보드 클릭 등의 이벤트 처리, 화면 업데이트, 버전 업데이트 점검 등의 여러 스레드가 수행될 것입니다. 이 중에서 사용자와 즉각적으로 소통해야 하는 마우스/키보드 처리나 이에 따른 화면 업데이트 등의 스레드가 더 높은 우선 순위를 가질 것입니다. 버전 업데이트 점검등은 보통 사용자가 작업중일 확률이 적은 심야 시간대나, 사용량이 적을 때(유튜브 등의 작업을 하고 있지 않을 때) 수행할 것입니다.

  3. 일상생활에 비유를 하자면 [옷을 입는다]와 [차를 타러간다] 두 프로세스에 대해서 당연히 [옷을 입는다]가 우선순위를 가져야 합니다.

    1. [옷을 입는다] 프로세스의 내부 스레드를 보자면 {속옷을 입는다}, {바지를 입는다}, {외투를 입는다} 등의 여러 스레드가 있는데 이 중에서는 {속옷을 입는다}스레드가 더 높은 우선순위를 가져야 합니다. {바지를 입는다}를 먼저 수행하게 되면 우스꽝스럽게 외출하게 되겠죠.

 

0

인프런 AI 인턴

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

프로세스 스케줄링과 스레드 스케줄링은 컴퓨터가 여러 작업을 효율적으로 관리하는 방법론에 있어 중요한 개념입니다.

프로세스 스케줄링

  • 프로세스는 운영 체제가 관리하는 실행 중인 프로그램의 독립적인 개체를 의미합니다. 여러 개의 프로세스가 있을 때, 운영 체제는 CPU를 어떻게 효율적으로 할당할지를 결정하는데 이를 프로세스 스케줄링이라고 합니다.
  • 주로 운영 체제 레벨에서 스케줄러가 어떤 프로세스가 CPU 자원을 사용할지를 결정합니다.

스레드 스케줄링

  • 스레드는 프로세스의 실행 단위로, 하나의 프로세스는 여러 스레드를 가질 수 있습니다. 스레드 스케줄링은 특정 프로세스 내에서 어떤 스레드가 CPU에 할당될지를 결정합니다.
  • 사용자 스레드와 커널 스레드가 있으며, 자바에서의 스레드 관리는 JVM이 이러한 스레드를 관리할 수 있도록 여러 메커니즘을 지원합니다.

CPU 코어와 스레드 실행

  • 일반적으로 하나의 CPU 코어는 한 번에 하나의 스레드만 실행할 수 있습니다. 그러나, 현대의 CPU는 여러 코어를 가지며, 각 코어가 동시에 여러 스레드를 처리할 수 있어 병렬처리를 가능하게 합니다.
  • 이를 통해 동시에 여러 작업이 수행되는 것처럼 보이지만, 실제로는 매우 빠른 전환(Context Switching)을 통해 이러한 효과를 달성합니다.

관련된 유사한 질문으로는 쓰레드 질문에서 컨텍스트 스위칭과 멀티스레드에 대한 개념을 다루고 있습니다. 또한, CPU Threads에서는 여러 스레드가 CPU 코어에서 어떻게 관리되는지를 설명합니다.

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

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

0

85

1

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

0

73

2

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

0

74

2

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

0

136

1

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

0

83

1

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

0

94

2

메모리 가시성 문제 질문

0

72

1

Future4-이유 질문

0

64

1

오타 제보

0

76

2

runnable 질문

0

95

2

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

0

111

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