抢占式调度
首先我们来说一个概念就是CPU是如何来分配这个资源的,其实就是抢占式的,两个进程会同时去抢CPU的资源,CPU会随机选择一个进程来让他运行一段时间,这种我们叫做“抢占式调度”
并发
我们重点说一下并发,并发其实就是指在同一时间段发生,比如我们人在白天八点到晚上八点这个时间段,我们会吃饭、会午休、会上班,然后我们会交替去做这些事情,那么我们可以称这些事情是并发的
并发从微观来看,它其实是交替执行的
当你在测试的时候可能会发现你的主线程和子线程其实是没有交替执行的
例如我写了这么一段代码
package experiment;
import java.io.*;
class tre implements Runnable {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
System.out.println("新线程"+i);
}
}
}
public class C {
public static void main(String[] args) throws IOException {
tre tr=new tre();
Thread t=new Thread(tr);
t.start();
for (int i = 0; i < 10; i++) {
System.out.println(i);
}
}
}
我的测试结果是这样的
那么导致这种结果的原因大多是因为我们的循环次数太少了我们把次数加大就可以看到结果
并发和并行的区别
并行是指两个或者多个事件在同一时刻发生;而并发是指两个或多个事件在同一时间间隔发生。
并行是在不同实体上的多个事件,并发是在同一实体上的多个事件。可以理解成并行是指有多条“马路”,车在不同的马路上跑。而并发是指只有一条路,有不同的车在上面跑。
并行是在多台处理器上同时处理多个任务。如 hadoop 分布式集群,并发是在一台处理器上“同时”处理多个任务。
注意单核CPU是无法做到并行的
所以并发的目标就是利用好每一个核的资源,并行就是将多个核利用起来,以达到最高性能。
进程
进程其实很好理解,其实可以理解成就是一个一个的应用程序,我们可以通过电脑的任务管理器看看
线程
我们先看看百度的解释:
线程(英语:thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。在Unix
System V及SunOS中也被称为轻量进程(lightweight processes),但轻量进程更多指内核线程(kernel
thread),而把用户线程(user thread)称为线程。
线程是独立调度和分派的基本单位。线程可以为操作系统内核调度的内核线程,如Win32线程;由用户进程自行调度的用户线程,如Linux平台的POSIX Thread;或者由内核与用户进程,如Windows 7的线程,进行混合调度。
同一进程中的多条线程将共享该进程中的全部系统资源,如虚拟地址空间,文件描述符和信号处理等等。但同一进程中的多个线程有各自的调用栈(call stack),自己的寄存器环境(register context),自己的线程本地存储(thread-local storage)。
一个进程可以有很多线程,每条线程并行执行不同的任务。
在多核或多CPU,或支持Hyper-threading的CPU上使用多线程程序设计的好处是显而易见,即提高了程序的执行吞吐率。在单CPU单核的计算机上,使用多线程技术,也可以把进程中负责I/O处理、人机交互而常被阻塞的部分与密集计算的部分分开来执行,编写专门的workhorse线程执行密集计算,从而提高了程序的执行效率。
对于我的理解就是一个软件看成一个房子,那么房子里面会有家具,家具会有自己的工作原理及路径,那么他们都是在自己的线程上面进行工作的。比如冰箱,他会制冷,制冷的程序是在它冰箱自己的线程上面运行的。再比如微波炉会加热,那么它加热的程序也是在它自己的线程上运行的。它们各种各样的家具组合在一起才成了这个房子。
以上是本人对并发、并行、进程以及线程的理解,如有错误,欢迎指出!!感谢阅读