Skip to content

shubhamv108/concurrency-multithreading

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Thread

  • Lightweight process responsible for executing a task

Process vs Thread

  • 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.

PCB

  • Process Id
  • Process state
  • Process priority
  • Accounting Information
  • Program Counter
  • CPU Register
  • PCB Pointers
  • .....

TCB

  • 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

Address Space

valid addresses in memory that are available for process.

Process in Java

https://www.geeksforgeeks.org/java-lang-process-class-java/

Links

Concurrency vs Parallelism (ToDo)

Parallel
  • multiple things at same time
  • genuine simultaneous execution
Concurrency
  • multiple things together but not same time
  • appearance of simultaneous execution (by interleaving of processes in time)

False Sharing

Critical Section

a piece of code that accesses a shared resource, usually a variable or data structure.

Race Condition

a software error that occurs when multiple threads access a shared resource

Intermediate Program

  • Consists of 1 or * race conditions;
  • the o/p of program is not deterministic & varies from run to run.

Mutual Exclusion

no two processes can exist in the critical section at any given point of time

InterProcess Communication

  • coordinate and synchronize between processes
  • ways
    1. Pipes
    2. Signals
    3. Buffers: Message queues etc
    4. Sockets

Shared memory

  • Common memory region from PCB

AssemblerInstructions

ldsub

load/store unsigned instruction byte (locked version of atomic exchange)

xchg

atomic exchange