Notice
Recent Posts
Recent Comments
Link
๊ด€๋ฆฌ ๋ฉ”๋‰ด

๋ชฉ๋ก2022/04 (31)

KoreanFoodie's Study

C++ ๊ธฐ์ดˆ ๊ฐœ๋… 15-5 : ์“ฐ๋ ˆ๋“œํ’€(ThreadPool) ๋งŒ๋“ค๊ธฐ

๋ชจ๋‘์˜ ์ฝ”๋“œ๋ฅผ ์ฐธ๊ณ ํ•˜์—ฌ ํ•ต์‹ฌ ๋‚ด์šฉ์„ ๊ฐ„์ถ”๋ฆฌ๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ์ž์„ธํ•œ ๋‚ด์šฉ์€ ๋ชจ๋‘์˜ ์ฝ”๋“œ์˜ ์”น์–ด๋จน๋Š” C++ ๊ฐ•์ขŒ๋ฅผ ์ฐธ๊ณ ํ•ด ์ฃผ์„ธ์š”! ThreadPool ๊ฐ„๋‹จ ์š”์•ฝ ThreadPool ์— ์šฐ๋ฆฌ๊ฐ€ ์›ํ•˜๋Š” ์ž‘์—…์„ ์ถ”๊ฐ€ํ•˜๋ฉด, ์“ฐ๋ ˆ๋“œํ’€์— ์žˆ๋Š” ์“ฐ๋ ˆ๋“œ๊ฐ€ ์ด๋ฅผ ๋งก์•„ ์ž‘์—…ํ•˜๊ฒŒ ๋œ๋‹ค. ์ด ๊ธ€์—์„œ๋Š” ์“ฐ๋ ˆ๋“œ์— ์ƒˆ๋กœ์šด ์ž‘์—…์„ ์ถ”๊ฐ€ํ•˜๋Š” ์ผ์„ queue ๋ฅผ ํ†ตํ•ด ์ฒ˜๋ฆฌํ•œ๋‹ค. ์ด๊ณณ์˜ ๊ตฌํ˜„์„ ๊ธฐ์ดˆ๋กœ ํ•˜์—ฌ ์ž‘์„ฑํ–ˆ๋‹ค. ๋ชจ๋“  ์“ฐ๋ ˆ๋“œ๊ฐ€ ์ž‘์—…์ค‘์ด์–ด๋„ ์ƒˆ๋กœ์šด ์ž‘์—…์„ ์ถ”๊ฐ€ํ•ด๋„ ์ƒ๊ด€์—†๋‹ค! ํด๋ž˜์Šค ์„ค๊ณ„ํ•˜๊ธฐ ๋จผ์ € ์“ฐ๋ ˆ๋“œ๋“ค์„ ๋ณด๊ด€ํ•  ์ปจํ…Œ์ด๋„ˆ๊ฐ€ ํ•„์š”ํ•˜๋‹ค. // ์ด Worker ์“ฐ๋ ˆ๋“œ์˜ ๊ฐœ์ˆ˜. size_t num_threads_; // Worker ์“ฐ๋ ˆ๋“œ๋ฅผ ๋ณด๊ด€ํ•˜๋Š” ๋ฒกํ„ฐ. std::vector worker_threads_; ํŽธ์˜์ƒ, ์“ฐ๋ ˆ๋“œํ’€์—์„œ ๋Œ์•„๊ฐ€๋Š” ์“ฐ๋ ˆ๋“œ๋“ค์„ ..

Tutorials/C++ : Beginner 2022. 4. 21. 14:10
C++ ๊ธฐ์ดˆ ๊ฐœ๋… 15-4 : future, promise, packaged_task, async

๋ชจ๋‘์˜ ์ฝ”๋“œ๋ฅผ ์ฐธ๊ณ ํ•˜์—ฌ ํ•ต์‹ฌ ๋‚ด์šฉ์„ ๊ฐ„์ถ”๋ฆฌ๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ์ž์„ธํ•œ ๋‚ด์šฉ์€ ๋ชจ๋‘์˜ ์ฝ”๋“œ์˜ ์”น์–ด๋จน๋Š” C++ ๊ฐ•์ขŒ๋ฅผ ์ฐธ๊ณ ํ•ด ์ฃผ์„ธ์š”! ๋™๊ธฐ์™€ ๋น„๋™๊ธฐ C++ ์ฝ”๋“œ๋Š” ์ˆœ์ฐจ์ ์œผ๋กœ ์‹คํ–‰๋œ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด, ํŒŒ์ผ์„ ์ฝ๊ณ , ์ฝ์€ ํŒŒ์ผ๋กœ ์–ด๋–ค ์ž‘์—…์„ ํ•˜๊ณ , ๋งˆ์ง€๋ง‰์œผ๋กœ ํŒŒ์ผ๊ณผ ๊ด€๊ณ„์—†๋Š” ์ž‘์—…์„ ์ˆ˜ํ–‰ํ•˜๋Š” ์ฝ”๋“œ๊ฐ€ ์žˆ๋‹ค๊ณ  ๊ฐ€์ •ํ•ด ๋ณด์ž. ์ด ๊ฒฝ์šฐ, ํŒŒ์ผ๊ณผ ๊ด€๊ณ„์—†๋Š” ์ž‘์—…์„ ํ•˜๊ธฐ ์œ„ํ•ด ํŒŒ์ผ์„ ์ฝ๊ธฐ๊นŒ์ง€ ๊ธฐ๋‹ค๋ ค์•ผ ํ•˜๋Š” ์ง€์—ฐ ์‹œ๊ฐ„์ด ์กด์žฌํ•œ๋‹ค. ์ด์ „์— ๋ฐฐ์šด ์“ฐ๋ ˆ๋“œ๋ฅผ ์ด์šฉํ•˜๋ฉด ์ด ์ž‘์—…์„ ๋น„๋™๊ธฐ์ ์œผ๋กœ ๋ฐ”๊พธ์–ด ์ค„ ์ˆ˜๋„ ์žˆ๋‹ค. void file_read(string* result) { string txt = read("a.txt"); *result = do_something_with_txt(txt); } int main() { string result; t..

Tutorials/C++ : Beginner 2022. 4. 20. 14:19
C++ ๊ธฐ์ดˆ ๊ฐœ๋… 15-3 : atomic ๊ฐ์ฒด์™€ memory order

๋ชจ๋‘์˜ ์ฝ”๋“œ๋ฅผ ์ฐธ๊ณ ํ•˜์—ฌ ํ•ต์‹ฌ ๋‚ด์šฉ์„ ๊ฐ„์ถ”๋ฆฌ๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ์ž์„ธํ•œ ๋‚ด์šฉ์€ ๋ชจ๋‘์˜ ์ฝ”๋“œ์˜ ์”น์–ด๋จน๋Š” C++ ๊ฐ•์ขŒ๋ฅผ ์ฐธ๊ณ ํ•ด ์ฃผ์„ธ์š”! ํŒŒ์ดํ”„๋ผ์ด๋‹ ๋‹ค์Œ๊ณผ ๊ฐ™์€ ์ฝ”๋“œ๊ฐ€ ์žˆ๋‹ค๊ณ  ํ•˜์ž. int a = 0; int b = a + 1; a = 1; ์ง๊ด€์ ์œผ๋กœ๋Š” b = a + 1 ์ด a = 1 ๋ณด๋‹ค ๋จผ์ € ์‹คํ–‰๋  ๊ฒƒ ๊ฐ™์ง€๋งŒ, ์ปดํŒŒ์ผ๋Ÿฌ๊ฐ€ ์–ด์…ˆ๋ธ”๋ฆฌ ์–ธ์–ด๋กœ ๋ฒˆ์—ญํ•œ ๊ฒƒ์„ ๋ณด๋ฉด a = 1 ์ด ๋” ๋จผ์ € ์‹คํ–‰๋˜๊ธฐ๋„ ํ•œ๋‹ค. ๋ฌผ๋ก  b ์™€ a ์—๋Š” ๊ฐ๊ฐ 1์ด๋ผ๋Š” ๊ฐ’์ด ์ œ๋Œ€๋กœ ๋“ค์–ด๊ฐ€์ง€๋งŒ, ์ปดํŒŒ์ผ๋Ÿฌ๋Š” ์ž‘์—…์˜ ํšจ์œจ์„ฑ์„ ์œ„ํ•ด ์ฝ”๋“œ์˜ ์‹คํ–‰์ˆœ์„œ๋ฅผ ๋ณ€๊ฒฝํ•œ๋‹ค. ์ด๋ฅผ ํŒŒ์ดํ”„๋ผ์ด๋‹์ด๋ผ๊ณ  ๋ถ€๋ฅธ๋‹ค. ์ด๋Š” ์ตœ์ ํ™”๋ฅผ ์œ„ํ•ด ์–ด์…ˆ๋ธ”๋ฆฌ ๋ช…๋ น์–ด๋ฅผ ํšจ์œจ์ ์œผ๋กœ ๋ฐฐ์น˜ํ•˜๋Š” ๊ณผ์ •์„ ์˜๋ฏธํ•œ๋‹ค. ์ˆ˜์ • ์ˆœ์„œ(Modification Order) ๋ช…๋ น์–ด๋ฅผ ๋’ค์ฃฝ๋ฐ•์ฃฝ์œผ๋กœ ์‹คํ–‰ํ•˜๋Š”๋ฐ๋„ ์–ด๋–ป๊ฒŒ ์ œ๋Œ€๋กœ..

Tutorials/C++ : Beginner 2022. 4. 19. 10:23
C++ ๊ธฐ์ดˆ ๊ฐœ๋… 15-1 : ์“ฐ๋ ˆ๋“œ(thread)์˜ ๊ธฐ์ดˆ์™€ ์‹ค์Šต

๋ชจ๋‘์˜ ์ฝ”๋“œ๋ฅผ ์ฐธ๊ณ ํ•˜์—ฌ ํ•ต์‹ฌ ๋‚ด์šฉ์„ ๊ฐ„์ถ”๋ฆฌ๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ์ž์„ธํ•œ ๋‚ด์šฉ์€ ๋ชจ๋‘์˜ ์ฝ”๋“œ์˜ ์”น์–ด๋จน๋Š” C++ ๊ฐ•์ขŒ๋ฅผ ์ฐธ๊ณ ํ•ด ์ฃผ์„ธ์š”! ํ”„๋กœ์„ธ์Šค์™€ ์“ฐ๋ ˆ๋“œ CPU ์ฝ”์–ด์—์„œ ๋Œ์•„๊ฐ€๋Š” ํ”„๋กœ๊ทธ๋žจ ๋‹จ์œ„๋ฅผ ์“ฐ๋ ˆ๋“œ(Thread) ๋ผ๊ณ  ๋ถ€๋ฅธ๋‹ค. ์ฆ‰, CPU ์˜ ์ฝ”์–ด ํ•˜๋‚˜์—์„œ๋Š” ํ•œ ๋ฒˆ์— ํ•œ ๊ฐœ์˜ ์“ฐ๋ ˆ๋“œ์˜ ๋ช…๋ น์„ ์‹คํ–‰์‹œํ‚ค๊ฒŒ ๋œ๋‹ค. ํ”„๋กœ์„ธ์Šค๋Š” ์—ฌ๋Ÿฌ ๊ฐœ์˜ ์“ฐ๋ ˆ๋“œ๋กœ ์ด๋ฃจ์–ด์ง€๋Š”๋ฐ, ํ”„๋กœ์„ธ์Šค์™€ ์“ฐ๋ ˆ๋“œ์˜ ์ฐจ์ด๋Š” ๋ฉ”๋ชจ๋ฆฌ๋ฅผ ๊ณต์œ ํ•˜๋Š๋ƒ ํ•˜์ง€ ์•Š๋Š๋ƒ์˜ ์ฐจ์ด์ด๋‹ค. ๊ฐ ์ฝ”์–ด์—์„œ๋Š” ์ฝ”์–ด๊ฐ€ ๋Œ์•„๊ฐ€๋Š”๋ฐ, ์ปจํ…์ŠคํŠธ ์Šค์œ„์นญ (Context Switching) ์„ ํ†ตํ•ด ์“ฐ๋ ˆ๋“œ๊ฐ€ ๋ฒˆ๊ฐˆ์•„๊ฐ€๋ฉฐ ์‹คํ–‰๋œ๋‹ค. ๋ณ‘๋ ฌํ™”(Parallelizable) ๊ฐ€๋Šฅํ•œ ์ž‘์—… ์“ฐ๋ ˆ๋“œ๋ฅผ ์ด์šฉํ•ด ๋ณ‘๋ ฌํ™”๋ฅผ ์ ์šฉํ•˜๋ฉด ๋”์šฑ ๋น ๋ฅธ ์ž‘์—…์ด ๊ฐ€๋Šฅํ•œ ๊ฒฝ์šฐ๊ฐ€ ์žˆ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด, ๋‹ค์Œ๊ณผ ๊ฐ™์ด ํ”ผ๋ณด๋‚˜์น˜ ์ˆ˜์—ด์„ ๊ตฌํ•˜๋Š”..

Tutorials/C++ : Beginner 2022. 4. 19. 10:23