C++/Thread
![[Thread] std::unique_lock](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2FcAnXWD%2FbtrHpQbiHG5%2FAAAAAAAAAAAAAAAAAAAAALPUu-kNnGVEOtctjjYjb2LMcq_smBZKd-4NcInxuFrx%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3DlguHHPAG8XkPvwZj%252FuasbGsCMtU%253D)
[Thread] std::unique_lock
std::unique_lock std::lock_guard와 비슷하지만 더 많은 기능을 가지고 있다. Example Code #include #include #include #include struct MInt { std::mutex mtx; int num = 0; }; void plus1(MInt& mi) { std::unique_lock lck(mi.mtx); mi.num++; } int main() { MInt mi; std::thread t1(plus1, std::ref(mi)); std::thread t2(plus1, std::ref(mi)); t1.join(); t2.join(); std::cout
![[Thread] std::mutex](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2Fb02pyC%2FbtrHoOKnMwm%2FAAAAAAAAAAAAAAAAAAAAAApyiEroaAqd-56X5FFcVooIM2TLg5nVCJfWMxI2TPd-%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3DXz6QyLynN5xJZAvwYZY5LoCBqHg%253D)
[Thread] std::mutex
std::mutex cppreference 참고 Lock - mutex가 이미 Lock상태일 때 다시 Lock을 거는 행위는 Undefined 되어있다. Unlock - mutex를 Unlock할 때 Lock되어있지 않는 행위는 Undefined 되어있다. Example Code #include #include #include #include struct MInt { std::mutex mtx; int num = 0; }; void plus1(MInt& mi) { mi.mtx.lock(); // mi.mtx.lock(); // 1. 락을 2번 거는 행위 mi.num++; mi.mtx.unlock(); // 2. 락을 걸지 않았는데 unlock을 시도 } int main() { MInt mi; std::t..
![[Thread] Mutex(뮤텍스)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2FcCoKSU%2FbtrHj39sCAD%2FAAAAAAAAAAAAAAAAAAAAAGoH3VYZRWgECi7qQcpgUDQro79DJqV0oSXl84H9CC9y%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3DPZoygVyDoeibbBA%252F3XnyhvRvojw%253D)
[Thread] Mutex(뮤텍스)
Mutex(뮤텍스)란? mutex란 Data race를 해결하는 가장 기초적인 방법이다. mutex는 Data race뿐 아니라 Race condition까지 해결해준다. 더보기 Race condition 공유되는 메모리 공간과는 상관 없이 thread가 어떠한 순서로 엮이느냐에 따라 결과값이 달라질 때 발생한다. Example Code #include #include #include #include void printThreadID() { std::cout
![[Thread] std::jthread (조이닝 쓰레드)](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2Fb8RMMl%2FbtrHdIc1O3l%2FAAAAAAAAAAAAAAAAAAAAAPsqVPaYOXhcOu7QXGq_L7Mk3BAJbIYcIgLma1LVKD0Z%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3DjkEJbYsAV6trlGwvRo4r%252FDSYkOU%253D)
[Thread] std::jthread (조이닝 쓰레드)
std::jthread (C++20)란? C++20부터 추가가 되었기 때문에 아직 범용적으로 사용되고 있지는 않다. std::thread의 단점을 어느정도 보완했는지 정도만 알면된다. Example Code : 일반적인 thread를 사용하는 경우 void fn() { std::cout
![[Thread] thread_local](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2Fcgfagj%2FbtrHcKhfwaH%2FAAAAAAAAAAAAAAAAAAAAAGI4d1wl6wkjKmCsv_YDtPIq_59wVc0rno0GqHCMa7LX%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3D5edU8ZEsCL95QnX6DtivvdDO4nA%253D)
[Thread] thread_local
thread_local (C++11) 이란? thread_local 키워드는 global이나 static과 비슷한 기능을 한다. global과 static은 프로세스 전체의 Life Cycle을 가지고 있는 반면 thread_local로 만들어진 변수는 각각의 thread에 대한 Life Cycle을 가지게 된다. Example Code int globalNum = 0; thread_local int tlNum = 0; void fn() { int fnNum = 2; std::cout
![[Thread] std::thread Argument](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2FbCg5vh%2FbtrFjzaHFMH%2FAAAAAAAAAAAAAAAAAAAAACydaa6zCrTWlEM4xV82hJCsDt2HsH0VUfpteZv2yAB4%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3DreSHL0JYOcP787acLSRfPBAVdsQ%253D)
[Thread] std::thread Argument
새로운 thread에 argument 전달 방법 바로 예제 코드를 보자. Example Code #include #include #include void fn(int a, std::string s) { std::cout
![[Thread] std::thread](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2FIVLPL%2FbtrFjyiqs6a%2FAAAAAAAAAAAAAAAAAAAAAFP282k-H_8EHaxmwNK12ro0pLce05CUS5GC7Hk2Cx2V%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3DiJXuDFwJAaMRZdXgVxhBSTnvQYk%253D)
[Thread] std::thread
std::thread thread에 대한 기본적인 내용부터 알아본다. Constructor Constructor를 보면 Thread를 동작시키기 위해서는 3번째 정의처럼 함수를 같이 넘겨줘야한다. 또한, Move Constructor는 정의가 되어있는 반면 Copy Constructor는 삭제되어있는걸 볼 수 있다. Example Code #include #include #include #include void fn() { std::cout
![[Thread] Introduction](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdna%2FocGR4%2FbtrEwx6OflR%2FAAAAAAAAAAAAAAAAAAAAAI2MC5ZBmv597lvXtVQCJwiUd5IPWghvh8E6IbF_C4qm%2Fimg.png%3Fcredential%3DyqXZFxpELC7KVnFOS48ylbz2pIh7yKj8%26expires%3D1761922799%26allow_ip%3D%26allow_referer%3D%26signature%3DaWmFwtE56j9ibMRBBBYB%252Bi9wmsk%253D)
[Thread] Introduction
Thread 하나의 프로세스에서 여러 동작을 동시에 진행시키는 것이 가능하다. Code, Data, Heap영역은 하나의 프로세스에서 공유되고, Stack은 각 Thread 별로 가지고 있다. 이러한 Multi Thread Process 프로그램을 우리가 알고 있는 메모리 그림으로 알고 있는 것도 유용하다. 이러한 메모리 공간에 두번째 Thread(t1)이 생긴다면 그 Thread는 중간에 새로운 Stack 시작점을 가지고 각각의 Thread의 진행 상황에 따라서 독립적으로 Stack을 쌓아가고 해제시킨다. 하지만 Heap이나 Static 공간의 데이터는 공유하기 때문이 각각의 Thread에서 접근이 가능하다. C++에서는 이러한 개념의 Thread를 std::thread를 통해서 생성할 수 있다. Mo..