sleep_for과 yield 차이 질문드립니다.
897
작성한 질문수 25
안녕하세요! 멀테스레딩 강의(Lock 구현 부분) 수강 중에 제가 제대로 이해가 안 가는 부분이 있어서 질문드립니다.
구체적으로 강의 코드에서 sleep_for와 yield의 내부적 동작?을 저는
yield(): lock이 잠겨있는 경우, system time slice에 상관없이 바로 context switching이 발생해, 해당 스레드가 다시 운영체제 스케줄링 큐에 들어가 운영체제가 다시 실행시켜 줄 때까지 대기
sleep_for(n): lock이 잠겨있는 경우, yield와 마찬가지로 컨텍스트 스위칭이 바로 발생하는데, n시간동안 해당 스레드가 sleep thread 큐에 저장되어 있다가, 그 다음에 스케줄링큐로 들어가서 이후에 다시 실행될때까지 대기
이해했는데, 이게 제대로 이해한게 맞을까요?
특히 sleep_for의 동작이 이해가 잘 안가는데, 스택오버플로우에서는
sleep_for(n)의 경우 최소 n시간 이상을 block한다는데, 해당 스레드가 블록되었다는 말이 컨텍스트 스위칭이 되어있다는걸까요? 또 sleep thread queue는 운영체제에서 관리하는 개념일까요?
(제대로 이해를 못해서 질문이 두서 없는 점 죄송합니다....)
답변 1
0
안녕하세요, 인프런 AI 인턴이에요. sleep_for과 yield의 차이점에 대해 설명해 드리겠습니다.
yield() 함수는 현재 스레드가 락(lock)을 가지고 있더라도, 제어를 CPU 스케줄러에게 넘기고 대기열에서 빠르게 우선순위를 다시 매깁니다. 하지만, 다시 실행될 때는 현재 상태를 그대로 유지합니다.
그리고, sleep_for(n) 함수는 현재 스레드를 n시간 동안 블록합니다. 블록된 스레드는 실행 대기열에서 제거됩니다. 그리고 일정 시간이 지난 뒤, 운영체제의 스케줄러에 의해 실행 대기열에 다시 집어넣어져 다시 실행됩니다. 따라서, sleep_for을 사용하는 스레드는 일시적으로 스케줄링 대기 큐를 벗어나게 됩니다.
마지막으로, sleep thread queue에 대해서 여쭤보셨는데요. sleep thread queue는 운영체제에서 관리하는 개념입니다. sleep 함수로 대기 중인 스레드는 sleep thread queue에 저장되며, 일정 시간이 경과한 후에 운영체제에서 스케줄러에 넘겨져 실행 대기열에 들어가게 됩니다.
저희가 설명한 내용으로 조금이나마 도움이 되셨기를 바랍니다. 감사합니다.
writeLock을 잡을때 꼭 empty 상태여야하는 이유?
0
36
2
Memory Pool에서 오버플로우 질문입니다.
0
73
2
포토폴리오 및 진로 관련하여 고민입니다.
0
129
1
포토폴리오 관련 고민입니다.
0
66
1
실무에서도 alloc, 스마트포인터 등을 구현해서 쓰는지 궁금합니다.
0
89
2
성능 테스트 결과
0
108
2
게임 서버 Stateful, Stateless 진로 고민
0
133
1
WaitOnAddress와 Sleep의 차이 질문
0
84
1
궁금한거 있습니다.
0
84
2
JobTimer 구동 스레드
0
108
2
TryPop() 동작 관련 질문
0
81
1
로드맵 C#서버 C++서버 방향성 질문
0
151
2
스레드 id를 출력할떄 메인스레드 id도 출력되나요?
0
73
1
생명주기를 위한 의도적 복사
0
88
2
락프리의 실무에서 사용 질문
0
147
2
32bit threadID와 16비트 상위 WriteFlag에 대해
0
105
2
mutex와 sleep 차이점
0
120
1
실무에서는 어떠한 코드 스타일을 사용하는지 궁금합니다
0
161
2
Stomp Allocator의 Release함수에 대한 질문입니다.
0
98
1
공부법 관련해서
0
184
2
MakeShared 함수 관련
0
114
1
지금까지 서버코어에서 만든 내용에 대해 궁금한 점이 있어서 질문 드립니다.
0
145
2
운영체제관련 질문입니다
0
132
1
send하려는 데이터 크기가 크면 memcpy에서 문제가 발생할 것 같습니다.
0
120
2





