Unit 3 - Practice Quiz

CSE316 50 Questions
0 Correct 0 Wrong 50 Left
0/50

1 What is a 'Race Condition' in Operating Systems?

A. A situation where processes compete for the CPU scheduler
B. A condition where the operating system runs faster than the hardware
C. A condition where a process races to finish before the time quantum expires
D. A situation where several processes access and manipulate the same data concurrently and the outcome depends on the order of execution

2 Which of the following is NOT a requirement for a solution to the Critical Section Problem?

A. Mutual Exclusion
B. processor Speed
C. Bounded Waiting
D. Progress

3 What does 'Mutual Exclusion' imply in the context of the Critical Section Problem?

A. Processes must share the same memory address space
B. If a process is executing in its critical section, then no other processes can be executing in their critical sections
C. All processes must execute their critical sections simultaneously
D. The operating system excludes processes from using the CPU

4 What is a Semaphore?

A. A protected integer variable that can only be accessed via two atomic operations
B. A hardware instruction
C. A queue of processes waiting for I/O
D. A specialized CPU register

5 In a Semaphore, what does the 'wait' (or P) operation do?

A. Increments the semaphore value
B. Sets the semaphore value to zero
C. Decrements the semaphore value
D. Reads the semaphore value without changing it

6 What is the main disadvantage of a Spinlock?

A. It is difficult to implement
B. It causes context switching
C. It requires busy waiting, wasting CPU cycles
D. It cannot handle multiple processes

7 A binary semaphore is also known as a:

A. Monitor
B. Mutex lock
C. Counting semaphore
D. Spinlock

8 Which hardware instruction is commonly used to implement mutual exclusion?

A. LoadAndStore
B. JumpAndLink
C. PushAndPop
D. TestAndSet

9 What is the 'Bounded Waiting' requirement?

A. A process must wait for a fixed amount of time
B. There exists a bound on the number of times other processes are allowed to enter their critical sections after a process has made a request to enter its critical section
C. The critical section size must be bounded
D. Processes must wait in a queue indefinitely

10 In the Producer-Consumer problem using a bounded buffer, when does the Producer wait?

A. When the mutex is unlocked
B. When the buffer is empty
C. When the buffer is full
D. When the Consumer is sleeping

11 Which of the following is a high-level synchronization construct that ensures mutual exclusion automatically?

A. Monitor
B. Peterson's Solution
C. Semaphore
D. Spinlock

12 In the Dining Philosophers problem, deadlock occurs if:

A. Philosophers eat sequentially
B. The philosophers do not speak to each other
C. All philosophers pick up their left chopstick simultaneously
D. One philosopher picks up both chopsticks

13 What is Peterson's Solution used for?

A. Solving the Critical Section problem for two processes
B. Scheduling threads
C. Handling hardware interrupts
D. Managing memory fragmentation

14 In Peterson's solution, which variables are shared between processes?

A. start and finish
B. semaphore and mutex
C. lock and key
D. turn and flag

15 What problem is the Readers-Writers problem primarily concerned with?

A. Ensuring exclusive access for writers while allowing multiple concurrent readers
B. Preventing readers from reading shared data
C. Allowing multiple writers to write simultaneously
D. Synchronizing two writers only

16 What happens to threads that call 'wait' on a Condition Variable in a Monitor?

A. They continue executing
B. They are terminated
C. They are suspended and placed in a waiting queue
D. They enter a busy-wait loop

17 Which of the following is NOT shared by threads of the same process?

A. Program Counter and Stack
B. Global variables
C. Code section
D. Open files

18 What is a Heavyweight Process compared to a Thread?

A. A process with no memory
B. A process with a single thread of control
C. A kernel-level thread
D. A thread with a large stack

19 Which multithreading model maps many user-level threads to a single kernel thread?

A. Many-to-One Model
B. Many-to-Many Model
C. One-to-One Model
D. Two-Level Model

20 What is a limitation of the Many-to-One multithreading model?

A. The entire process blocks if one thread makes a blocking system call
B. It is too complex to implement
C. It does not support user-level threads
D. It consumes too many kernel resources

21 Which multithreading model provides more concurrency than Many-to-One but doesn't require a kernel thread for every user thread?

A. Many-to-Many Model
B. Single Thread Model
C. Independent Model
D. One-to-One Model

22 What is 'Scheduler Activation'?

A. A signal to kill a process
B. A mechanism for communication between the user-thread library and the kernel
C. The process of activating the CPU clock
D. A hardware interrupt that starts the scheduler

23 Which standard defines the API for thread creation and synchronization (Pthreads)?

A. POSIX
B. ANSI
C. Java
D. Win32

24 What is the function of pthread_join()?

A. Unlocks a mutex
B. Terminates a thread
C. Waits for a specific thread to terminate
D. Creates a new thread

25 A Precedence Graph is a directed acyclic graph used to:

A. Show the hierarchy of file systems
B. Map virtual memory to physical memory
C. Describe the execution dependencies among concurrent processes
D. Visualize the memory usage of a process

26 What defines 'Co-operating Processes'?

A. Processes that can affect or be affected by other executing processes
B. Processes running on different computers
C. Processes that are completely independent
D. Processes that do not share data

27 In the context of process hierarchy, what system call is typically used in Unix/Linux to create a new process?

A. new()
B. fork()
C. create()
D. spawn()

28 If a Semaphore S has a value of 10, and 5 P (wait) operations and 3 V (signal) operations are performed, what is the final value of S?

A. 12
B. 10
C. 2
D. 8

29 What is the 'Bakery Algorithm' designed to solve?

A. Deadlock recovery
B. The Critical Section problem for N processes
C. The Producer-Consumer problem
D. Memory allocation

30 Which of the following is true regarding User-Level Threads (ULT)?

A. Context switching is faster than Kernel-Level Threads
B. They require hardware support
C. They cannot run on any OS
D. The kernel is aware of all ULTs

31 In the One-to-One multithreading model, what is the main drawback?

A. It is not standard
B. It does not support multiprocessors
C. Creating a user thread requires creating a corresponding kernel thread, which creates overhead
D. It blocks the whole process on I/O

32 What is an 'Upcall' in the context of Scheduler Activations?

A. A call from a user thread to the kernel
B. A notification from the kernel to the thread library
C. Uploading data to the cloud
D. increasing the priority of a thread

33 Which synchronization primitive is typically used to solve the Reader-Writer problem to prevent writer starvation?

A. Disable Interrupts
B. Semaphores with a priority queue
C. TestAndSet
D. Spinlocks

34 What is 'Priority Inversion'?

A. A lower priority process holds a lock needed by a higher priority process
B. Inverting the bits of the semaphore
C. Assigning priority 0 to the most important process
D. The scheduler runs processes in reverse order

35 How does the 'Swap' hardware instruction assist in synchronization?

A. It moves a process to swap space
B. It swaps the content of two memory words atomically
C. It switches between user and kernel mode
D. It changes the process ID

36 In a Monitor, if process P executes x.signal() and process Q was waiting on x, and Q immediately executes while P waits, this strategy is called:

A. Signal and Continue (Mesa semantics)
B. Busy Waiting
C. Signal and Wait (Hoare semantics)
D. Broadcast

37 Which component allows a thread to have its own copy of data?

A. Semaphore
B. Global Heap
C. TLS (Thread Local Storage)
D. Shared Memory

38 The problem where a producer tries to put an item into a full buffer is handled by:

A. Killing the consumer
B. Overwriting the oldest item
C. Putting the producer to sleep
D. Discarding the item

39 Why is disabling interrupts not a viable solution for mutual exclusion in multiprocessor systems?

A. It requires too much power
B. It causes the OS to crash
C. It only disables interrupts on one processor, not all
D. It is too slow

40 What is 'Busy Waiting'?

A. The CPU executing a NOP instruction
B. A process waiting for I/O
C. A process repeatedly checking a condition until it becomes true
D. A process waiting in a queue

41 Which of the following is a valid state for a Java thread?

A. WAITING
B. BLOCKED
C. RUNNING
D. All of the above

42 In the context of threads, what is 'cancellation'?

A. Removing a semaphore
B. Stopping the CPU
C. Deleting the thread library
D. Terminating a thread before it has completed

43 Deferred cancellation of a thread means:

A. The thread is cancelled after 1 minute
B. The thread is cancelled immediately
C. The thread cancels the parent process
D. The thread checks periodically if it should terminate

44 A solution to the Dining Philosophers problem using a monitor restricts a philosopher to pick up chopsticks only if:

A. The right neighbor is eating
B. Both neighbors are not eating
C. They have a ticket
D. The left neighbor is eating

45 Which type of semaphore can take any non-negative integer value?

A. Mutex
B. Counting Semaphore
C. Binary Semaphore
D. Spinlock

46 What defines a 'Thread Safe' function?

A. It can be called from multiple threads simultaneously without producing incorrect results
B. It runs very fast
C. It uses no memory
D. It creates a new thread

47 In the 'Sleeping Barber' problem (a variation of producer-consumer), what happens if the customer arrives and the waiting room is full?

A. The customer leaves
B. The barber cuts two heads at once
C. The customer waits outside
D. The customer wakes the barber

48 What is the benefit of the 'Grand Central Dispatch' (GCD) technology in macOS/iOS?

A. It creates infinite threads
B. It manages thread pools and scheduling automatically
C. It replaces the kernel
D. It increases clock speed

49 Concurrency vs Parallelism: Which statement is true?

A. They are exactly the same
B. Parallelism requires multiple processors/cores, Concurrency does not
C. Parallelism is software only
D. Concurrency requires multiple processors

50 What is the primary purpose of a Condition Variable?

A. To allow threads to wait for a specific condition to become true
B. To store the process ID
C. To lock a file
D. To increment a counter