进程

进程是具有独立功能的程序在一个数据集合上运行的过程,它是系统进行资源分配和调度的一个独立单位。系统利用进程控制块来管理和控制进程

线程

线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针、程序计数器等),但代码区是共享的,即不同的线程可以执行同样的函数。

多线程

多线程是指程序中包含多个执行流,即在一个程序中可以同时运行多个不同的线程来执行不同的任务,
也就是说允许单个程序创建多个并行执行的线程来完成各自的任务。

优点

可以提高 CPU 的利用率。在多线程程序中,一个线程必须等待的时候,CPU 可以运行其它的线程而不是等待,这样就大大提高了程序的效率。

缺点

  1. 线程也是程序,所以线程需要占用内存,线程越多占用内存也越多;
  2. 多线程需要协调和管理,所以需要 CPU 时间跟踪线程;
  3. 线程之间对共享资源的访问会相互影响,必须解决竞用共享资源的问题;
  4. 线程太多会导致控制太复杂,最终可能造成很多 Bug;

进程和线程

线程相对于进程的优点:

  1. 开销小
  2. 资源共享性好。

线程相对于进程的缺点:

  1. 共享资源需要耗费一定的锁资源,同步相对复杂。
  2. 一个线程崩溃可能导致整个进程崩溃,这个当然是自己的应用程序有问题

进程间通信

  1. 管道
  2. 消息队列
  3. 信号量
  4. 共享内存

未完待续…..