进程和线程

进程:是系统进行资源分配和调度的一个独立单位

在多道程序环境下,允许多个程序并发执行,此时它们将失去封闭性,并具有间断性,为此引入了进程的概念,以便更好地描述和控制程序的并发执行,实现操作系统的并发性和共享性。

进程的特征:

1、动态性。进程是程序的一次执行,有创建,活动,暂停,终止等过程,具有一定的生命周期

2、并发性。同时存在于内存中,能在一段时间内同时进行,提高资源利用率

3、独立性。进程是一个能独立运行,独立获得资源和独立接受调度的基本单位

4、异步性。由于进程的相互制约,使进程具有执行的间断性

5、结构性。进程实体是由程序段、数据段和进程控制段三部分组成

进程的状态与转换:

1、运行状态

2、就绪状态

3、阻塞状态

4、创建状态

5、结束状态

引入进程的目的,是为了更好的使多道程序并发执行,以提高资源利用率和系统吞吐量,增加并发程度;引入线程,则是为了减少程序在并发执行时所付出的时空开销,提高操作系统的并发性能。

线程:线程是进程中的一个实体,他可与同属一个进程的其他线程共享进程所拥有的全部资源。同一个进程的多个线程之间可以并发执行。线程本身不拥有系统资源,只拥有一点在运行中必不可少的资源。

操作系统可以同时运行多个任务。打个比方,你一边在用浏览器上网,一边在听MP3,一边在用Word赶作业,这就是多任务,至少同时有3个任务正在运行。还有很多任务悄悄地在后台同时运行着,只是桌面上没有显示而已。

现在,多核CPU已经非常普及了,但是,即使过去的单核CPU,也可以执行多任务。由于CPU执行代码都是顺序执行的,那么,单核CPU是怎么执行多任务的呢?

答案就是操作系统轮流让各个任务交替执行,任务1执行0.01秒,切换到任务2,任务2执行0.01秒,再切换到任务3,执行0.01秒……这样反复执行下去。表面上看,每个任务都是交替执行的,但是,由于CPU的执行速度实在是太快了,我们感觉就像所有任务都在同时执行一样。

有些进程还不止同时干一件事,比如Word,它可以同时进行打字、拼写检查、打印等事情。在一个进程内部,要同时干多件事,就需要同时运行多个“子任务”,我们把进程内的这些“子任务”称为线程(Thread)。

多线程并发的安全问题:

当多线程并发访问同一个资源对象的时候,可能出现线程不安全的问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值