User-LevelThreads
User-level threads implement in user-level libraries, rather
than via systems calls, so thread switching does not need to call operating
system and to cause interrupt to the kernel. In fact, the kernel knows nothing
about user-level threads and manages them as if they were single-threaded
processes.
Advantages:
The most obvious advantage of this technique is that a user-level threads package can be implemented on an Operating System that does not support threads. Some other advantages are
Advantages:
The most obvious advantage of this technique is that a user-level threads package can be implemented on an Operating System that does not support threads. Some other advantages are
- User-level threads do not require modification to operating systems.
- Simple
Representation:
Each thread is represented simply by a PC, registers, stack and a small control block, all stored in the user process address space. - Simple
Management:
This simply means that creating a thread, switching between threads and synchronization between threads can all be done without intervention of the kernel. - Fast and
Efficient:
Thread switching is not much more expensive than a procedure call.
Disadvantages:
- There is a lack of coordination between threads and operating system kernel. Therefore, process as whole gets one time slice irrespective of whether process has one thread or 1000 threads within. It is up to each thread to relinquish control to other threads.
- User-level threads require non-blocking systems call i.e., a multithreaded kernel. Otherwise, entire process will blocked in the kernel, even if there are run able threads left in the processes. For example, if one thread causes a page fault, the process blocks.
Kernel-LevelThreads
In this method, the kernel knows about and manages the
threads. No runtime system is needed in this case. Instead of thread table in
each process, the kernel has a thread table that keeps track of all threads in
the system. In addition, the kernel also maintains the traditional process
table to keep track of processes. Operating Systems kernel provides system call
to create and manage threads.
Advantages:
Advantages:
- Because kernel has full knowledge of all threads, Scheduler may decide to give more time to a process having large number of threads than process having small number of threads.
- Kernel-level threads are especially good for applications that frequently block.
Disadvantages:
- The kernel-level threads are slow and inefficient. For instance, threads operations are hundreds of times slower than that of user-level threads.
- Since kernel must manage and schedule threads as well as processes. It requires a full thread control block (TCB) for each thread to maintain information about threads. As a result there is significant overhead and increased in kernel complexity.
No comments:
Post a Comment