让你学会与理解Java的线程与并发(一,线程与进程,并发)

本文介绍了线程与进程的基本概念,包括线程作为指令流和进程作为资源分配单位的特性。阐述了多线程中的线程切换、超线程的概念,并对比了进程间的资源共享与通信复杂性。同时,讨论了线程数量与效率的关系,以及并发与并行的区别。最后,提到了线程与进程在实际应用中的考虑因素。
摘要由CSDN通过智能技术生成

多线程相信大家都不怎么陌生,面试题也有不小的概率能够遇见下面就让我们来看看线程有关的知识吧!

线程与进程是什么(面试题)?

线程:

1,一个线程就是一个指令流,将一条条指令按照一定顺序交给cpu进行执行。

2,一个进程可以分配一个到多个线程

3,在java中线程是最小的调度单位

单线程:当一个线程从头执行到尾,并没有多余分支。

多线程: 一个线程在一定时间下执行没有执行完,数据进行保存,切换到另一个线程当中执行。

线程的切换(os)

多线程中执行二条命令时,先放第一条命令进行执行,执行到一定时间后,没有计算完就存储到缓存当中,再执行第二条命令,相同时间后没有计算完,也放入缓冲中,取出第一个计算数据进行计算,反复循环直到计算完成。

进程:

1,当一个程序被执行,从磁盘加载这个程序的代码到内存当中,就开启一个进程。

2.进程可以当作程序的一个实例,大部分程序可以运行多个进程(比如同时打开,qq,微信,浏览器等)

3,在Java种进程是资源分配的最小单位,在Windows下进程是不活动的,只是作为线程的容器

超线程(扩展):

一个cpu当中有计算单位(ALU),指向执行指令单位(pc),寄存器(peglsters :存储数据),因为ALU计算速度特别快,当一个ALU配置上二个pc与二个寄存器时,这个时候称为超线程。

二者的比较

1,进程基本上是相互独立的,而线程存在于进程内,是进程的子集。

2,进程可以共享资源,如内存共享空间,使得线内部的线程共享。

3,进程的通信复杂(同一台就是计算机之间的通信加IPC,不同计算机之间的通信,需要网络,并遵循协议如HTTP等)

4,线程通信简单,二个不同线程可以访问同一个共享变量(因为它们共享进程当中的内存)

是不是线程越多,效率就越高?

不一定:当线程愈来愈多时候,线程之间的切换就会需要消耗大量时间,所有效率不一定高。

并行与并发

并发(concurrent):

当一个cpu要执行多个线程的时候,需要使用任务调度器进行分配,(比如说有三个线程,当执行第一个线程一定时间后(没有执行完,数据进行存储),就进行下一个线程(相同时间),在下一个,相同时间下交换,直到线程完成的过程叫并发

同一时间来应对多件事的能力

并行(parallel):

当cpu的核心(cpu不只一个核心),同一时间下在处理不同线程过程叫并行(如下图)

 当核不够时,就可以发生并发来解决。同一时间来动手做多件事的能力

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

韶光不负

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值