<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/><title>Glossary : Concurrency, Parallelism, Multitasking, etc</title></head><body><article class="page serif"><header><div class="page-header-icon undefined"><img class="icon" src="https://www.notion.so/icons/help-alternate_red.svg"/></div><h1 class="page-title">Glossary : Concurrency, Parallelism, Multitasking, etc</h1><p class="page-description"></p><table class="properties"><tbody><tr class="property-row property-row-created_by"><th><span class="icon property-icon"><svg role="graphics-symbol" viewBox="0 0 16 16" style="width:14px;height:14px;display:block;fill:rgba(55, 53, 47, 0.45);flex-shrink:0" class="typesCreatedBy"><path d="M8 15.126C11.8623 15.126 15.0615 11.9336 15.0615 8.06445C15.0615 4.20215 11.8623 1.00293 7.99316 1.00293C4.13086 1.00293 0.938477 4.20215 0.938477 8.06445C0.938477 11.9336 4.1377 15.126 8 15.126ZM8 10.4229C6.05176 10.4229 4.54785 11.1133 3.83008 11.9131C2.90039 10.9082 2.33301 9.55469 2.33301 8.06445C2.33301 4.91992 4.84863 2.39746 7.99316 2.39746C11.1377 2.39746 13.6738 4.91992 13.6738 8.06445C13.6738 9.55469 13.1064 10.9082 12.1699 11.9131C11.4521 11.1133 9.94824 10.4229 8 10.4229ZM8 9.30176C9.32617 9.30859 10.3516 8.18066 10.3516 6.71094C10.3516 5.33008 9.31934 4.18164 8 4.18164C6.6875 4.18164 5.6416 5.33008 5.64844 6.71094C5.65527 8.18066 6.68066 9.28809 8 9.30176Z"></path></svg></span>Created by</th><td><span class="user"><img src="Glossary%20Concurrency,%20Parallelism,%20Multitasking,%20e%201116cd51990d80a08415fe1cabb4e8af/IMG_2295.jpg" class="icon user-icon"/>JiaLin Huang</span></td></tr><tr class="property-row property-row-last_edited_time"><th><span class="icon property-icon"><svg role="graphics-symbol" viewBox="0 0 16 16" style="width:14px;height:14px;display:block;fill:rgba(55, 53, 47, 0.45);flex-shrink:0" class="typesCreatedAt"><path d="M8 15.126C11.8623 15.126 15.0615 11.9336 15.0615 8.06445C15.0615 4.20215 11.8623 1.00293 7.99316 1.00293C4.13086 1.00293 0.938477 4.20215 0.938477 8.06445C0.938477 11.9336 4.1377 15.126 8 15.126ZM8 13.7383C4.85547 13.7383 2.33301 11.209 2.33301 8.06445C2.33301 4.91992 4.84863 2.39746 7.99316 2.39746C11.1377 2.39746 13.6738 4.91992 13.6738 8.06445C13.6738 11.209 11.1445 13.7383 8 13.7383ZM4.54102 8.91211H7.99316C8.30078 8.91211 8.54004 8.67285 8.54004 8.37207V3.8877C8.54004 3.58691 8.30078 3.34766 7.99316 3.34766C7.69238 3.34766 7.45312 3.58691 7.45312 3.8877V7.83203H4.54102C4.2334 7.83203 4.00098 8.06445 4.00098 8.37207C4.00098 8.67285 4.2334 8.91211 4.54102 8.91211Z"></path></svg></span>Last edited</th><td><time>@2024年9月30日 10:38</time></td></tr><tr class="property-row property-row-multi_select"><th><span class="icon property-icon"><svg role="graphics-symbol" viewBox="0 0 16 16" style="width:14px;height:14px;display:block;fill:rgba(55, 53, 47, 0.45);flex-shrink:0" class="typesMultipleSelect"><path d="M1.91602 4.83789C2.44238 4.83789 2.87305 4.40723 2.87305 3.87402C2.87305 3.34766 2.44238 2.91699 1.91602 2.91699C1.38281 2.91699 0.952148 3.34766 0.952148 3.87402C0.952148 4.40723 1.38281 4.83789 1.91602 4.83789ZM5.1084 4.52344H14.3984C14.7607 4.52344 15.0479 4.23633 15.0479 3.87402C15.0479 3.51172 14.7607 3.22461 14.3984 3.22461H5.1084C4.74609 3.22461 4.45898 3.51172 4.45898 3.87402C4.45898 4.23633 4.74609 4.52344 5.1084 4.52344ZM1.91602 9.03516C2.44238 9.03516 2.87305 8.60449 2.87305 8.07129C2.87305 7.54492 2.44238 7.11426 1.91602 7.11426C1.38281 7.11426 0.952148 7.54492 0.952148 8.07129C0.952148 8.60449 1.38281 9.03516 1.91602 9.03516ZM5.1084 8.7207H14.3984C14.7607 8.7207 15.0479 8.43359 15.0479 8.07129C15.0479 7.70898 14.7607 7.42188 14.3984 7.42188H5.1084C4.74609 7.42188 4.45898 7.70898 4.45898 8.07129C4.45898 8.43359 4.74609 8.7207 5.1084 8.7207ZM1.91602 13.2324C2.44238 13.2324 2.87305 12.8018 2.87305 12.2686C2.87305 11.7422 2.44238 11.3115 1.91602 11.3115C1.38281 11.3115 0.952148 11.7422 0.952148 12.2686C0.952148 12.8018 1.38281 13.2324 1.91602 13.2324ZM5.1084 12.918H14.3984C14.7607 12.918 15.0479 12.6309 15.0479 12.2686C15.0479 11.9062 14.7607 11.6191 14.3984 11.6191H5.1084C4.74609 11.6191 4.45898 11.9062 4.45898 12.2686C4.45898 12.6309 4.74609 12.918 5.1084 12.918Z"></path></svg></span>Tags</th><td></td></tr></tbody></table></header><div class="page-body"><h1 class="">TL;DR</h1><p class="">Parallelism, multitasking, and concurrency are general concepts</p><table class="simple-table"><tbody><tr><td class=""></td><td class="" style="width:102.99348449707031px">Concurrency</td><td class="" style="width:286.1640625px">Parallelism </td></tr><tr><td class="">Multitasking</td><td class="" style="width:102.99348449707031px">🟢</td><td class="" style="width:286.1640625px">Possible on multiple CPUs</td></tr><tr><td class="">Multiprocessing</td><td class="" style="width:102.99348449707031px">🟢</td><td class="" style="width:286.1640625px">Possible on multiple CPUs</td></tr><tr><td class="">Multithreading</td><td class="" style="width:102.99348449707031px">🟢</td><td class="" style="width:286.1640625px">possible if no GIL (eg. Jython, IronPython). <br/>For CPU-bound is a no, <br/>but IO-bound is possible.<br/></td></tr><tr><td class=""><mark class="highlight-red"><strong>async</strong></mark>hronous</td><td class="" style="width:102.99348449707031px">🟢</td><td class="" style="width:286.1640625px">usually not</td></tr><tr><td class=""><mark class="highlight-red"><strong>sync</strong></mark>hronous</td><td class="" style="width:102.99348449707031px">🟢</td><td class="" style="width:286.1640625px">mostly not</td></tr><tr><td class="">One CPU</td><td class="" style="width:102.99348449707031px">🟢</td><td class="" style="width:286.1640625px">❌</td></tr><tr><td class="">CPUs</td><td class="" style="width:102.99348449707031px">🟢</td><td class="" style="width:286.1640625px">🟢</td></tr></tbody></table><p class="">
</p><p class="">
</p><h1 class="">Multitasking</h1><p class="">The concept of running multiple tasks, which can be implemented on both single and multiple processors.</p><ul class="bulleted-list"><li style="list-style-type:disc">Time Slicing: Like a super scheduler dividing a day into 5-minute slots, but here it&#x27;s milliseconds.</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Time Sharing: Using fast context switching to make each task think it&#x27;s the only one running.</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Time Sharing is the concept, Time slicing is one specific strategy of Time sharing.</li></ul><p class="">
</p><p class=""><strong>Multitasking includes:</strong></p><ol type="1" class="numbered-list" start="1"><li>multiprocessing (parallelism on multiple CPUs)</li></ol><ol type="1" class="numbered-list" start="2"><li>multithreading (can be concurrent on a single CPU or parallel on multiple CPUs)</li></ol><p class="">The meaning depends on context. In systems, multitasking usually refers to multiprocessing. In programming, it often means multithreading.</p><h1 class="">Multiprocessing</h1><p class="">The ability to run multiple tasks simultaneously using multiple processors (CPUs). </p><p class="">Always concurrent, but parallel only when multiple CPUs are actually used.</p><h1 class="">Synchronous/sync</h1><p class="">The definition varies in different situations:</p><ul class="bulleted-list"><li style="list-style-type:disc">Happening, existing, or arising at precisely <strong>the same time</strong>?</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Operations tasks are performed <strong>one at a time</strong>?</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">As <strong>sequential</strong></li></ul><h1 class="">Asynchronous/async</h1><p class="">A programming paradigm where operations can be initiated without waiting for previous operations to complete, allowing for non-blocking execution.</p><p class="">Events occur independently of the main program flow, allowing the program to continue running without waiting for an operation to complete.</p><p class=""><mark class="highlight-red"><strong>Async programming is often used for I/O-bound tasks</strong></mark> to improve application responsiveness and resource utilization.</p><p class=""><strong>Implementations include:</strong></p><ol type="1" class="numbered-list" start="1"><li>Callbacks</li></ol><ol type="1" class="numbered-list" start="2"><li>Promises</li></ol><ol type="1" class="numbered-list" start="3"><li>Coroutines</li></ol><h3 class="">Asynchronous vs. Threading</h3><p class="">Same: to achieve concurrency</p><p class="">Many languages implement async features without using multiple threads:</p><ul class="bulleted-list"><li style="list-style-type:disc">JavaScript, for example, is <strong>single-threaded</strong> and uses an event loop for async operations.</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Python&#x27;s <code>asyncio</code> framework builds async functionality on top of <strong>a single thread</strong>.</li></ul><p class=""><strong>Language-Specific Implementations:</strong></p><ul class="bulleted-list"><li style="list-style-type:disc">JavaScript/Node.js:<ul class="bulleted-list"><li style="list-style-type:circle"><strong>General</strong>:<mark class="highlight-red"><strong> Primarily single-threaded</strong></mark>, using an event loop for asynchronous operations through callbacks, Promises, and async/await.</li></ul><ul class="bulleted-list"><li style="list-style-type:circle"><strong>Worker Threads</strong> (introduced in Node.js 10.5.0): <ul class="bulleted-list"><li style="list-style-type:square">limited multithreading capabilities within a single process in javascript runtime. Allow running JavaScript in background threads for CPU-intensive tasks.</li></ul></li></ul><ul class="bulleted-list"><li style="list-style-type:circle"><strong>Node.js Child Processes</strong>: Enable true multiprocessing by spawning separate OS processes, allowing full utilization of multi-core systems.</li></ul></li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Python: The asyncio library provides async capabilities using coroutines, all running <mark class="highlight-red"><strong>on a single thread</strong></mark>.</li></ul><p class="">Node.js, features like Worker Threads and Child Processes can be considered &quot;<mark class="highlight-red"><strong>out-of-band</strong></mark>&quot; mechanisms. They provide additional concurrency and parallelism options beyond the core single-threaded model, but their usage is optional and specific to certain use cases.</p><p class="">
</p><h1 class="">Parallelism</h1><p class="">Must have <mark class="highlight-red"><strong>CPUs</strong></mark> to do it.</p><p class="">
</p><h1 class="">Concurrency</h1><p class="">Concurrency is a blueprint: how to organize and manage multiple tasks that might happen at the same time, whether or not they actually run simultaneously.</p><p class="">It&#x27;s an abstract concept that can be achieved through multiple ways:</p><ul class="bulleted-list"><li style="list-style-type:disc">Multitasking</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Multiprocessing</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Multithreading</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Async</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Sync</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">One CPU? OK</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Many CPUs? Great</li></ul><p class=""><div class="indented"><p class="">
</p></div></p><p class="">
</p><p class="">Although some programming languages like Python provide multiprocessing APIs that can be used in user-level code, their core implementation still relies on system-level operations.</p><table class="simple-table"><tbody><tr><td class="" style="width:195.18228149414062px"></td><td class="" style="width:131.99609375px">kernel</td><td class="">user</td></tr><tr><td class="" style="width:195.18228149414062px">multiprocessing</td><td class="" style="width:131.99609375px">✅</td><td class=""></td></tr><tr><td class="" style="width:195.18228149414062px">multithreading</td><td class="" style="width:131.99609375px">✅</td><td class="">✅</td></tr><tr><td class="" style="width:195.18228149414062px">async (e.g. Python asyncio)</td><td class="" style="width:131.99609375px"></td><td class="">✅</td></tr></tbody></table><p class="">
</p><p class="">
</p><p class="">
</p><p class="">
</p><p class=""><a href="https://stackoverflow.com/questions/27435284/multiprocessing-vs-multithreading-vs-asyncio">https://stackoverflow.com/questions/27435284/multiprocessing-vs-multithreading-vs-asyncio</a></p></div></article><span class="sans" style="font-size:14px;padding-top:2em"></span></body>
~/
about
posts
frontbacknetworkoscloud
readings
css
bookmarks
archives
To live is to risk it all Otherwise you are just an inert chunk of randomly assembled molecules drifting wherever the Universe blows you
© 2024 jialin00.com Original content since 2022