线程和进程

定义

进程:具有一定独立功能的程序关于某个数据集合上的一次运行活动,它是系统进行资源分配和调度的一个独立单位。
线程:进程的一个实体,是CPU调度和分配的基本单位,线程基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器、一组寄存器和栈)。

引入线程的意义

  1. 易于调度
  2. 提高并发性,通过线程可以方便有效地进行并发。
  3. 开销小,创建线程比创建进程要快,所需要的开销更少。
  4. 有利于发挥多处理器的功能。

线程和进程的区别

  1. 一个线程属于且只属于一个进程;一个进程至少有一个线程。
  2. 同属于一个进程的所有线程共享给该线程的所有资源;不同的进程互相独立。
  3. 进程有进程控制块,线程有线程控制块,但线程控制块比进程控制块小得多,线程间切换代价小,进程间切换代价大。
  4. 进程是程序的一次执行,线程可以理解为程序中的一段程序片段的执行。
  5. 每个进程都有独立的内存空间,而线程共享其所属进程的内存空间。

疑问

1. 为什么要限制线程并发的数量?
如果不限制线程并发的数量,CPU的资源很快就会被耗尽,每个线程执行任务缓慢,因为CPU要把时间片分配给不同的线程对象,而且上下文切换也要耗时,最终会造成系统运行效率大幅降低。
2. 线程的数量会受到什么限制 ?
(1)cpu数量。对于一个CPU,线程数总是大于或等于核心数的。一个核心最少对应一个线程,但通过超线程技术,一个核心可以对应两个线程,也就是说它可以同时运行两个线程。
【补充】CPU的核心数是指物理上也就是硬件上存在着几个核心。比如,双核就是包括2个相对独立的CPU核心单元组。
(2)线程栈大小。
(3)操作系统位数。32位所支持的内存最大为4G,64位理论上是无限支持。
(4)进程最大内存。对于一个进程来说分给堆空间的越多,分给栈空间的就越少。
3. 线程在内存中会占用什么资源 ?
TCB(线程控制块)、程序计数器(指示被执行指令序列)、一组寄存器和堆栈(保留局部变量、少数状态参数和返回地址)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值