Learning Partnerships, Unit Catalogue 2008/09 |
AS30210 Multi-tasking systems |
Credits: 6 |
Level: Honours |
Semester: 1 at Weston College |
Semester: 1 at Wiltshire College |
Assessment: CW 70%, EX 30% |
Requisites: |
Aims: To explore the nature of concurrency, parallelism and inter-process communication and their role in practical computing applications.
Learning Outcomes: * An understanding of the nature of concurrency and parallelism and the theoretical and practical issues associated with each; * An understanding of inter-process communication in both shared and non-shared memory spaces. Skills: Intellectual: (T and A) Develop knowledge for analysing and managing concurrent processing and parallelism. Professional: (F and A) Gain an insight into the relationship between the needs of systems and the potential problems in coding them leading to an ability to decide on the nature of system problems. Practical: (T and A) Design and programming for the implementation of concurrent and parallel systems. Key: (F and A) Planning, designing and communication. (T: Taught, F: Facilitated, A: Assessed). Content: * Process management: the concept of a process and the scheduling of several processes. Operations on processes and the cooperation needed between processes. * Concurrent threads: programming multithreaded systems. * Concurrency v parallelism: the differences and similarities. * Multi-processor, multi-core processors and programming for parallel processes. * Operating systems and concurrent process. CPU context switching. Scheduling - heavy weight and light weight threads. Scheduling and real time systems. Critical sections and atomic actions. * Operating systems for multi processors systems and parallel processes. * Inter-process communication and process synchronization. Shared memory and low level synchronization primitives. High level language synchronization mechanisms. Resource allocation, deadlock and starvation * Distributed communication (non-shared memory). High level language mechanisms such as sockets and Remote Method Invocation (RMI-Java). |