重要概念知识点【并发、并行】【进程、线程】【同步、异步】

程序猿进阶知识点(重在理解)

什么是进程? 什么是线程?

  • 进程
   系统中正在运行的一个应用程序,程序一旦运行就是进程。
   即进程是指程序执行时的一个实例。

  • 线程
	线程是进程的一个实体。
	进程是资源分配的最小单位。
	线程是程序执行的最小单位。


进程和线程的主要区别

  • 进程拥有独立的堆栈空间和数据段,每当启动一个新的进程必须分配给它独立的地址空间,建立众多的数据表来维护它的代码段、堆栈段和数据段,系统开销比较大,而线程不一样,线程拥有独立的堆栈空间,共享数据段,它们彼此之间使用相同的地址空间,共享大部分数据,比进程更节俭,开销比较小,切换速度也比进程快,效率高。由于进程之间独立的特点,使得进程安全性比较高,也因为进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径。一个线程死掉就等于整个进程死掉
  • 同一个进程中所有线程共享该进程的所有资源,包括文件描述符,而不同过的进程资源相互独立。线程必定属于一个进程,而进程可以拥有多个线程而且至少拥有一个线程(主线程)
  • 进程之间互不干扰,相互独立,所以进程的通信机制相对很复杂,如管道,信号,消息队列,共享内存,套接字等通信机制,而线程由于共享数据段所以通信机制很方便,但要注意资源竞争(多线程同步)
  • 线程又称为轻量级进程,进程有进程控制块,线程有线程控制块

进程与线程的选择

  • 需要更稳定安全时,适合选择进程;需要速度时,选择线程更好。
  • 需要频繁创建销毁的优先使用线程创建和销毁进程代价是很大
  • 需要大量计算,切换频繁时用线程,还有耗时的操作使用线程可提高应用程序的响应线程的切换速度快

并发和并行

  • 并发交替做不同事的能力
  • 并行同时做不同事的能力

同步和异步的区别

  • 同步:阻塞

  • 异步:非阻塞 (实现机制:多线程)


发布了30 篇原创文章 · 获赞 14 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/fzl_blog/article/details/104025506
今日推荐