Home Links

Programs

A program is a list of instructions usually stored in a file (usually called an executable e.g. an elf file) stored on some memory device (e.g. a disk) that can be executed by a computer.

Process

A process is an instance of execution of a program. There can be multiple instances of a program, each one of which is a process e.g. multiple instances of your PC calculator program running at any one time.

A process describes a program loaded into computer memory along with all the resources it needs to run/execute e.g. registers, a program counter, a stack and a heap. Each process has a seperate memory address space and is usually independent of other processes. This explains why your text processing program can freeze while other programs on your PC are functional.

A Process

Threads

A thread is a unit/sequence of execution within a process. Processes can have multiple threads working on different tasks at (almost) the same time. Threads within a process can share memory and resources. Each thread has it’s own registers and stack but the heap is shared. Threads can communicate with each other easily (due to the shared address space) but problems with one thread affect all threads and the process as a whole.

Threads

Culled from:

Fork me on GitHub