线程和进程

定义

进程:具有一定独立功能的程序关于某个数据集合上的一次运行活动,它是系统进行资源分配和调度的一个独立单位。
线程:进程的一个实体,是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(线程控制块)、程序计数器(指示被执行指令序列)、一组寄存器和堆栈(保留局部变量、少数状态参数和返回地址)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的线程进程是操作系统中两个基本的概念,它们在执行上下文中有着不同的含义: 1. **进程**(Process): 进程是操作系统分配资源的基本单位,每个进程都有自己的独立内存空间和系统资源。Java程序运行时会创建一个对应的JVM(Java Virtual Machine),JVM中可以有多个并发执行的线程进程的切换是由操作系统内核控制的,切换开销相对较高。 2. **线程**(Thread): 线程是在同一个进程中并行执行的轻量级实体,它们共享同一块内存空间,因此相比于进程线程之间的通信更快、切换更频繁。在Java中,每个Java应用至少有一个主线程,用户可以通过继承Thread类或实现Runnable接口来创建新的线程。 **主要区别**: - **资源占用**:进程拥有独立的内存空间,而线程共享进程的内存,所以线程更节省资源。 - **并发性**:同一进程内的线程可以直接相互访问数据,易于实现并发控制;而不同进程间的数据交换需要通过I/O操作。 - **调度粒度**:进程调度由操作系统进行,线程调度则由JVM或操作系统的用户级线程管理器完成,线程切换更快速。 - **同步与通信**:线程之间通常通过锁、条件变量等同步机制协作,而进程间的通信通常使用管道、消息队列等机制。 **相关问题**: 1. Java如何创建和管理线程? 2. 进程线程在性能优化上有什么考虑? 3. 在并发编程中,为什么要避免不必要的线程创建?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值