- Lightweight process responsible for executing a task
- Process is isolated. | Threads share memory.
- Process switching uses interface in operating system | Thread switching does not require to call a operating system and cause an interrupt to the kernel.
- PCB, Stack, Address space | PCB, TCB, Stack, common Address space
- A thread is a path of execution within a process. A process can contain multiple threads.
- more time for context switching. | less time for context switching.
- Process Id
- Process state
- Process priority
- Accounting Information
- Program Counter
- CPU Register
- PCB Pointers
- .....
- Thread ID
- Thread State
- CPU Information
- Program Counter
- Register contents
- Thread Priority
- Pointer to process that created this thread
- Pointers to other threads that were created by this thread
** https://www.geeksforgeeks.org/thread-control-block-in-operating-system/?ref=rp
valid addresses in memory that are available for process.
https://www.geeksforgeeks.org/java-lang-process-class-java/
- https://www.geeksforgeeks.org/thread-models-in-operating-system/?ref=rp
- https://www.geeksforgeeks.org/thread-in-operating-system/?ref=rp
- https://www.geeksforgeeks.org/mutex-lock-for-linux-thread-synchronization/?ref=rp
- https://www.geeksforgeeks.org/kernel-in-operating-system/?ref=rp
- https://www.geeksforgeeks.org/difference-between-user-level-thread-and-kernel-level-thread/?ref=rp
- https://www.geeksforgeeks.org/difference-between-process-and-kernel-thread/?ref=rp
- https://www.geeksforgeeks.org/difference-between-operating-system-and-kernel/?ref=rp
- multiple things at same time
- genuine simultaneous execution
- multiple things together but not same time
- appearance of simultaneous execution (by interleaving of processes in time)
- https://dzone.com/articles/what-false-sharing-is-and-how-jvm-prevents-it
- https://medium.com/@rukavitsya/what-is-false-sharing-and-how-jvm-prevents-it-82a4ed27da84
a piece of code that accesses a shared resource, usually a variable or data structure.
a software error that occurs when multiple threads access a shared resource
- Consists of 1 or * race conditions;
- the o/p of program is not deterministic & varies from run to run.
no two processes can exist in the critical section at any given point of time
- coordinate and synchronize between processes
- ways
- Pipes
- Signals
- Buffers: Message queues etc
- Sockets
- Common memory region from PCB
load/store unsigned instruction byte (locked version of atomic exchange)
atomic exchange