3. 线程概念篇/ 线程和进程的区别

线程(Thread)

理解:
1.线程其实是包含在进程中的
2.一个进程中可能有多个线程
3.每个线程都有一段自己要执行的逻辑(指令)
每个线程都是一个独立的“执行流”
4.同一个进程中的很多线程之间 共享了一些资源(内存资源、打开的文件)
5.不共享的资源:上下文/状态/优先级/记账信息 /每个线程要独立的参与CPU调度 / 内存中有一块特殊的区域(栈)是每个线程要独立一份

进程是操作系统分配资源的最小单位
线程是操作系统进行调度和执行的最小单位

在这里插入图片描述

一个进程最多能承载的线程数取决于

1.CPU的个数相关
2.和线程执行的任务类型有关
(a)CPU密集型:程序就一直在执行计算任务
(b)IO密集型:程序没咋进行计算,主要是进行输入输出操作

假设这个主机有8核CPU,那么就有以下两种极端情况
1.任务全部使用CPU计算的,那么线程的数目大概是8个左右
2.任务全部使用IO密集型的,理论上多少线程都可以

但是实际情况下要介于两者之间,在实践中要通过测试的方式来找到合适的线程数

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值