让你学会与理解Java的线程与并发(一,线程与进程,并发)
Posted 韶光不负
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了让你学会与理解Java的线程与并发(一,线程与进程,并发)相关的知识,希望对你有一定的参考价值。
多线程相信大家都不怎么陌生,面试题也有不小的概率能够遇见下面就让我们来看看线程有关的知识吧!
线程与进程是什么(面试题)?
线程:
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不只一个核心),同一时间下在处理不同线程过程叫并行(如下图)
当核不够时,就可以发生并发来解决。同一时间来动手做多件事的能力
以上是关于让你学会与理解Java的线程与并发(一,线程与进程,并发)的主要内容,如果未能解决你的问题,请参考以下文章