进程与线程的概念

什么是进程

进程的定义(来自百度):进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。
学过计算机专业的人,在学操作系统这门课程的时候,也是有接触过进程这个概念的。
定义里说得很清楚,操作系统进行分配资源和调度的资源时,面向的对象就是进程。也就是进程需要计算机的资源(内存、cpu等),也需要操作系统进行调度。
简单的上个例子:下图就是代表一个一个的进程,以及进程所占用的资源
在这里插入图片描述

什么是线程

前面进程的定义中有一句话:在当代面向线程设计的计算机结构中,进程是线程的容器。
也就是说进程是一个容器,它可以包含很多线程。
线程的定义(来自百度):线程(英语:thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。
定义里说的很清楚,一个进程中可以并发多个线程,这些线程都会执行自己的任务。
就拿网易云音乐的软件来说,启动软件后,对应有一个网易云的进程,而里面可以在播放歌曲的同时,滚动歌词,可以同时搜索音乐。我们可以把它理解这些都是线程。并且线程是并发。

线程并发的优点以及带来的问题

优点

线程并发的优点在于并发。在一个进程中的多个线程并不需要排队执行,而可以同时执行。假设A线程执行完任务需要10秒,B线程执行完任务需要20秒。假如线程不能并发执行,那么就需要30秒。如果线程可以同时执行,那就只需要20秒的时间就可以完成。
线程并发

问题

并发必然存在同时访问某一块资源或者更新某一块资源,也就是并发读写。这个时候就会出现并发读写普遍会遇到的问题,如脏读,写失效,为了解决这些问题,必然要有很多措施,如锁机制等等。本专栏后面的内容主要也就是这一块,介绍java多线程相关的技术。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值