Lecture Operating system concepts (9/ed) - Chapter 4: Threads
Số trang: 46
Loại file: ppt
Dung lượng: 4.36 MB
Lượt xem: 8
Lượt tải: 0
Xem trước 5 trang đầu tiên của tài liệu này:
Thông tin tài liệu:
In this chapter, the following content will be discussed: Overview, multicore programming, multithreading models, thread libraries, implicit threading, threading issues, operating system examples.
Nội dung trích xuất từ tài liệu:
Lecture Operating system concepts (9/ed) - Chapter 4: Threads Chapter 4: ThreadsOperating System Concepts – 9th Edition Silberschatz, Galvin and Gagne ©2013 Chapter 4: Threads Overview Multicore Programming Multithreading Models Thread Libraries Implicit Threading Threading Issues Operating System ExamplesOperating System Concepts – 9th Edition 4.2 Silberschatz, Galvin and Gagne ©2013 Objectives To introduce the notion(k/niệm) of a thread—a fundamental(căn bản) unit of CPU utilization(sử dụng) that forms the basis of multithreaded computer systems To discuss the APIs for the Pthreads, Windows, and Java thread libraries To explore several strategies that provide implicit(ẩn) threading To examine issues related to multithreaded programming To cover operating system support for threads in Windows and LinuxOperating System Concepts – 9th Edition 4.3 Silberschatz, Galvin and Gagne ©2013 Motivation(sự thúc đẩy) Most modern applications are multithreaded Threads run within application Multiple tasks with the application can be implemented by separate threads Update display Fetch(tìm nạp) data Spell checking Answer a network request Process creation is heavy-weight while thread creation is light- weight Can simplify code, increase efficiency(hiệu quả) Kernels are generally multithreadedOperating System Concepts – 9th Edition 4.4 Silberschatz, Galvin and Gagne ©2013 Multithreaded Server ArchitectureOperating System Concepts – 9th Edition 4.5 Silberschatz, Galvin and Gagne ©2013 Benefits Responsiveness(phản hồi)( – may allow continued execution if part of process is blocked, especially important for user interfaces Resource Sharing – threads share resources of process, easier than shared memory or message passing Economy – cheaper than process creation, thread switching lower overhead than context switching Scalability(k/năng m/rộng) – process can take advantage of multiprocessor architecturesOperating System Concepts – 9th Edition 4.6 Silberschatz, Galvin and Gagne ©2013 Multicore Programming Multicore or multiprocessor systems putting pressure on programmers, challenges include: Dividing activities Balance Data splitting Data dependency Testing and debugging Parallelism implies(hàm ý) a system can perform more than one task simultaneously(đồng thời) Concurrency supports more than one task making progress Single processor / core, scheduler providing concurrencyOperating System Concepts – 9th Edition 4.7 Silberschatz, Galvin and Gagne ©2013 Multicore Programming (Cont.) Types of parallelism Data parallelism – distributes subsets of the same data across multiple cores, same operation on each Task parallelism – distributing threads across cores, each thread performing unique operation As # of threads grows, so does architectural support for threading CPUs have cores as well as hardware threads Consider Oracle SPARC T4 with 8 cores, and 8 hardware threads per coreOperating System Concepts – 9th Edition 4.8 Silberschatz, Galvin and Gagne ©2013 Concurrency vs. Parallelism Concurrent execution on single-core system: Parallelism on a multi-core system:Operating System Concepts – 9th Edition 4.9 Silberschatz, Galvin and Gagne ©2013 Single and Multithreaded ProcessesOperating System Concepts – 9th Edition 4.10 Silberschatz, Galvin and Gagne ©2013 Amdahl’s Law Identifies(x/định) performance(hiệu năng) gains(tăng) from adding additional cores to an application that has both serial and parallel components S is serial portion N processing cores That is, if application is 75% parallel / 25% serial, moving from 1 to 2 cores results in speedup of 1.6 times As N approaches(phép tính) infinity(vô cực), speedup approaches 1 / S Serial portion of an application has disproportionate(ko cân đối) effect(hiệu ứng) on performance gained(tăng) by adding additional cores But does the law take into account contemporary(đương thời) multicoreOperating Systemsystems? Concepts – 9 Edition th 4.11 Silberschatz, Galvin and Gagne ©2013 User Threads and Kernel Threads User threads - management done by user-level threads library Three primary thread libraries: POSIX Pthre ...
Nội dung trích xuất từ tài liệu:
Lecture Operating system concepts (9/ed) - Chapter 4: Threads Chapter 4: ThreadsOperating System Concepts – 9th Edition Silberschatz, Galvin and Gagne ©2013 Chapter 4: Threads Overview Multicore Programming Multithreading Models Thread Libraries Implicit Threading Threading Issues Operating System ExamplesOperating System Concepts – 9th Edition 4.2 Silberschatz, Galvin and Gagne ©2013 Objectives To introduce the notion(k/niệm) of a thread—a fundamental(căn bản) unit of CPU utilization(sử dụng) that forms the basis of multithreaded computer systems To discuss the APIs for the Pthreads, Windows, and Java thread libraries To explore several strategies that provide implicit(ẩn) threading To examine issues related to multithreaded programming To cover operating system support for threads in Windows and LinuxOperating System Concepts – 9th Edition 4.3 Silberschatz, Galvin and Gagne ©2013 Motivation(sự thúc đẩy) Most modern applications are multithreaded Threads run within application Multiple tasks with the application can be implemented by separate threads Update display Fetch(tìm nạp) data Spell checking Answer a network request Process creation is heavy-weight while thread creation is light- weight Can simplify code, increase efficiency(hiệu quả) Kernels are generally multithreadedOperating System Concepts – 9th Edition 4.4 Silberschatz, Galvin and Gagne ©2013 Multithreaded Server ArchitectureOperating System Concepts – 9th Edition 4.5 Silberschatz, Galvin and Gagne ©2013 Benefits Responsiveness(phản hồi)( – may allow continued execution if part of process is blocked, especially important for user interfaces Resource Sharing – threads share resources of process, easier than shared memory or message passing Economy – cheaper than process creation, thread switching lower overhead than context switching Scalability(k/năng m/rộng) – process can take advantage of multiprocessor architecturesOperating System Concepts – 9th Edition 4.6 Silberschatz, Galvin and Gagne ©2013 Multicore Programming Multicore or multiprocessor systems putting pressure on programmers, challenges include: Dividing activities Balance Data splitting Data dependency Testing and debugging Parallelism implies(hàm ý) a system can perform more than one task simultaneously(đồng thời) Concurrency supports more than one task making progress Single processor / core, scheduler providing concurrencyOperating System Concepts – 9th Edition 4.7 Silberschatz, Galvin and Gagne ©2013 Multicore Programming (Cont.) Types of parallelism Data parallelism – distributes subsets of the same data across multiple cores, same operation on each Task parallelism – distributing threads across cores, each thread performing unique operation As # of threads grows, so does architectural support for threading CPUs have cores as well as hardware threads Consider Oracle SPARC T4 with 8 cores, and 8 hardware threads per coreOperating System Concepts – 9th Edition 4.8 Silberschatz, Galvin and Gagne ©2013 Concurrency vs. Parallelism Concurrent execution on single-core system: Parallelism on a multi-core system:Operating System Concepts – 9th Edition 4.9 Silberschatz, Galvin and Gagne ©2013 Single and Multithreaded ProcessesOperating System Concepts – 9th Edition 4.10 Silberschatz, Galvin and Gagne ©2013 Amdahl’s Law Identifies(x/định) performance(hiệu năng) gains(tăng) from adding additional cores to an application that has both serial and parallel components S is serial portion N processing cores That is, if application is 75% parallel / 25% serial, moving from 1 to 2 cores results in speedup of 1.6 times As N approaches(phép tính) infinity(vô cực), speedup approaches 1 / S Serial portion of an application has disproportionate(ko cân đối) effect(hiệu ứng) on performance gained(tăng) by adding additional cores But does the law take into account contemporary(đương thời) multicoreOperating Systemsystems? Concepts – 9 Edition th 4.11 Silberschatz, Galvin and Gagne ©2013 User Threads and Kernel Threads User threads - management done by user-level threads library Three primary thread libraries: POSIX Pthre ...
Tìm kiếm theo từ khóa liên quan:
Hệ điều hành Hệ điều hành nâng cao Operating System Computer System Organization Operating System Structures Multicore programmingGợi ý tài liệu liên quan:
-
Giáo trình Lý thuyết hệ điều hành: Phần 1 - Nguyễn Kim Tuấn
110 trang 438 0 0 -
Giáo trình Nguyên lý các hệ điều hành: Phần 2
88 trang 258 0 0 -
175 trang 255 0 0
-
173 trang 252 2 0
-
Giáo trình Nguyên lý hệ điều hành (In lần thứ ba): Phần 1 - PGS.TS. Hà Quang Thụy
98 trang 230 0 0 -
Đề tài nguyên lý hệ điều hành: Nghiên cứu tìm hiểu về bộ nhớ ngoài trong hệ điều hành Linux
19 trang 224 0 0 -
Bài thảo luận nhóm: Tìm hiểu và phân tích kiến trúc, chức năng và hoạt động của hệ điều hành Android
39 trang 217 0 0 -
Giáo trình Hệ điều hành: Phần 2
53 trang 198 0 0 -
Bài giảng Nguyên lý hệ điều hành (Bài giảng tuần 3) - Nguyễn Hải Châu
8 trang 194 0 0 -
Tài liệu học tập môn Tin cơ sở: Phần 1 - Phùng Thị Thu Hiền
100 trang 183 1 0