多线程(一)程序,进程,线程的区别与联系

程序、进程、线程的概念
程序是指令的有序集合,被存储在磁盘或其他的数据存储设备中,是一个静态概念,其本身没有任何运行的含义。
进程是指一个具有一定独立功能的程序关于某个数据集合的一次运行活动,是系统运行程序的基本单位,因此进程是动态的。
线程与进程相似,但线程是一个比进程更小的执行单位。一个进程在其执行的过程中可以产生多个线程。与进程不同的是同类的多个线程共享同一块内存空间和一组系统资源,所以系统在产生一个线程,或是在各个线程之间作切换工作时,负担要比进程小得多,也正因为如此,线程也被称为轻量级进程。

程序与进程的区别:

  1. 程序是指令的有序集合,是一个静态概念,其本身没有任何运行的含义。而进程是程序在处理机(电脑)上的一次执行过程,是动态的概念。
  2. 程序可以作为一种软件资料长期保存,而进程则是有一定生命周期的,它能够动态的产生和消亡。
  3. 进程是一个能独立运行的单位,能与其他进程并行活动。
  4. 进程是竞争计算机系统有限资源的基本单位,也是进行处理机调度的基本单位。程序无此该概念。
  5. 进程与程序之间无一一对应关系。不同的进程可以包含同一程序,同一程序在执行中也可以产生多个进程。
  6. 程序是记录在介质上指令的有序集合,而进程则由程序、数据和进程控制块3部分组成。

线程与进程的区别:

  1. 通常在一个进程中可以包含若干个线程,一个进程中至少有一个线程,线程是进程的子集。
  2. 线程是进程的一条执行路径。
  3. 进程是系统运行程序的基本单位,线程是CPU调度和执行的单位。
  4. 进程在执行过程中拥有独立的内存单元,不同的进程使用不同的内存空间,而一个进程中的多个线程共享一片相同的内存空间。
  5. 很多多线程是模拟出来的,真正的多线程是指有多个CPU(多核),一般多少个CPU就可以同时执行多少个线程。如果是模拟出来的多线程,即在一个CPU(单核)的情况下,在同一个时间点,CPU只能执行一个代码,因为切换的很快,所以就有同时执行的错觉。

对Java线程的认识

  1. 在程序运行时,即使没有自己创建多线程,后台也会有多个线程,如主线程,gc线程;
  2. main()称之为主线程,为系统的入口,用于执行整个程序。
  3. 在一个进程中,如果开辟了多个线程,线程的执行顺序由调度器安排调度,调度器是与操作系统紧密相关的,先后顺序是不能人为的干预。
  4. 对同一份资源操作时,会存在资源抢夺的问题,需要加入并发控制。
  5. 线程会带来额外的开销,如cpu调度时间,并发控制开销。每个线程在自己的工作内存交互,内存控制不当会造成数据不一致。

这部分关于多线程的面试题:
1、什么是线程?
线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位。程序员可以通过它进行多处理器编程,你可以使用多线程对 运算密集型任务提速。比如,如果一个线程完成一个任务要100毫秒,那么用十个线程完成改任务只需10毫秒。Java在语言层面对多线程提供了卓越的支 持,它也是一个很好的卖点。
2、进程,线程之间有什么区别?
进程是程序运行和资源分配的基本单位,一个程序至少有一个进程,一个进程至少有一个线程。进程在执行过程中拥有独立的内存单元,而多个线程共享内存资源,减少切换次数,从而效率更高。线程是进程的一个实体,是cpu调度和分派的基本单位,是比程序更小的能独立运行的基本单位。同一进程中的多个线程之间可以并发执行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值