Operative Systems
3
2024-2025
01000495
Digital Systems and Computers
Portuguese
English
Face-to-face
SEMESTRIAL
6.0
Elective
1st Cycle Studies
Recommended Prerequisites
Computer Programming; Data Structures and Algorithms; Microprocessors Systems.
Teaching Methods
Theoretical classes with presentation, using audiovisual means, of the concepts, principles, theories, and methodologies, and with the presentation of illustrative and application examples.
Practical laboratory classes, supervised by a professor: in these classes, some time is dedicated to the presentation of topics relevant to the practical handouts and to the laboratory works; And the rest of the time is dedicated to the development of practical handouts and laboratory works which require the application and combination of different concepts.
Learning Outcomes
Acquire knowledge about the internal functioning of operating systems (OS) and their modules, including, processes scheduling, memory management, virtual memory, disk scheduling, file systems, and concurrent programming; and basic knowledge about distributed systems. Acquire knowledge about techniques and algorithms related to operating systems. Acquire capacity to write good system code that explores in an optimized manner the functionalities of an operating system.
Acquiring competencies in analysis and synthesis, practical application of theoretical knowledge, solving problems, autonomous learning, adaptivity to new situations, informatics knowledge concerning the scope of study.
Work Placement(s)
NoSyllabus
Operating systems introductory and support concepts; General notions about computer architecture; Operating systems roles; Processes: description and control; Threads; Concurrency: mutual exclusion, synchronization and communication, deadlocks and starvation; Memory Management; Virtual memory; Scheduling of processes and threads; I/O management and disk scheduling; File management; Security in operating systems; Virtualization; Introduction to distributed operating systems; Operating systems applied to robotics and internet of things (IOS): examples of the Robot Operating System (ROS) and CONTIKI-OS for IOS; Systems programming.
Head Lecturer(s)
Rui Alexandre de Matos Araújo
Assessment Methods
Assessment
Frequency: 20.0%
Laboratory work or Field work: 30.0%
Exam: 50.0%
Bibliography
• Stallings, W. (2014) – Operating Systems - Internals and Design Principles, 8th Edition, Prentice-Hall.
• Silberschatz, A., Galvin, P.B., Gagne, G. (2013) – Operating System Concepts, 9th Edition, John Wiley and Sons.
• Robins, K.A., Robins, S. (2003) – Unix Systems Programming: Communication Concurrency, and Threads, Prentice-Hall.
• Marshall, D.A. (1999) – Programming in C: UNIX System Calls and Subroutines Using C, Cardiff University, UK, Internet.
• Kernighan, B.W., Ritchie, D.M. (1988) – The C Programming Language, 2ed, Prentice-Hall.
• Stevens, W.R. (1991) – UNIX Network Programming, 1ed, Prentice-Hall.