LInux系统篇系列已经更新了十期文章了,是不是对LInux系统有了初步了了解,学习是一个长期的基类过程,一份付出一分收获,共勉。本期文章咱们讲解下线程和进程的区别是什么?
大致区别如下图:
进程是什么?
进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位.
线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源.
一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行.
相对进程而言,线程是一个更加接近于执行体的概念,它可以与同进程中的其他线程共享数据,但拥有自己的栈空间,拥有独立的执行序列。
在串行程序基础上引入线程和进程是为了提高程序的并发度,从而提高程序运行效率和响应时间。
操作系统的设计,可以归结为三点:
(1)以多进程形式,允许多个任务同时运行;
(2)以多线程形式,允许单个任务分成不同的部分运行;
(3)提供协调机制,一方面防止进程之间和线程之间产生冲突,另一方面允许进程之间和线程之间共享资源。
区别:
进程和线程的主要差别在于它们是不同的操作系统资源管理方式。进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径。线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。
1)简而言之,一个程序至少有一个进程,一个进程至少有一个线程.
2)线程的划分尺度小于进程,使得多线程程序的并发性高。
3)另外,进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。
4)线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
5)从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。
优缺点:
线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源的管理和保护;而进程正相反。同时,线程适合于在SMP机器上运行,而进程则可以跨机器迁移。
如果大家喜欢的话,就在评论区留言吧!
下篇文章我们分享网络层。下面是本人整理的链接,能够帮助大家快速寻找文章。
linux系统篇链接:
Linux系统篇-网络协议栈之传输层(简单清晰)
Linux系统篇-网络协议栈-发送端之应用层(简单清晰)
Linux系统篇-网络协议栈之网络路径
linux系统篇-网络协议栈实现解析(1)网络协议栈初始化
Linux系统篇-内核的5个重要子系统
Linux系统篇-文件系统&虚拟文件系统
Linux系统篇-进程的管理与调度
Linux系统篇-内存管理(五分钟搞懂)
C++的知识点,下面几篇文章链接:
C++基础知识点第七天
C++基础知识点第六天
C++基础知识第五天(面试必备)
C++基础知识第四天(面试必备)
C++基础知识第三天(面试必备)
C++基础知识第二天
C++基础知识第一天
网络编程方面,可以查看以下几篇文章链接:
广播和多播、IGMP协议之套餐
ICMP协议、ping和Traceroute套餐
IPv6技术详解
高性能网络编程:单台服务器TCP最大并发链接数
TCP拥塞控制
高级网络编程之疑症:清掉TIME_WAIT的奇怪技巧
高级网络编程之疑症:TCP的延迟确认机制
高级网络编程之疑症:TCP的头号疼症TIME_WAIT状态(下篇)
高级网络编程之疑症:TCP的头号疼症TIME_WAIT
高级网络编程之疑症:TCP的Peer两端同时断开连接
高级网络编程之疑症:TCP连接的初始化序列号能否固定?
高级网络编程之疑症:初始化连接的SYN超时问题
高级网络编程之疑症:四次挥手能不能变成三次挥手呢?