JUC 多线程01--线程、进程概念

2023-10-20 10:07:27 浏览数 (1)

进程

正在进行中的程序。 每一个进程至少有一个线程。当程序运行时在内存空间中开辟一片独立空间。每一个进程都有一个执行顺序。 一个进程更象一个任务。 进程的内存原理:

  • 应用程序在执行时都会在内存中开辟一片内存空间并分配地址。进程用于标识这片空间,封装里面的控制单元。
  • 而线程就是进程中的控制单元。线程在控制着进程的执行。

进程和内存

每个进程都有自己的一套虚拟内存地址,用来给自己的进程空间编号。 进程空间的数据同样以字节为单位,依次增加。 从功能上说,虚拟内存地址和物理内存地址类似,都是为数据提供位置索引。 进程的虚拟内存地址相互独立。因此,两个进程空间可以有相同的虚拟内存地址,如0x10001000。 虚拟内存地址和物理内存地址又有一定的对应关系, 对进程某个虚拟内存地址的操作,会被CPU翻译成对某个具体内存地址的操作。

创建进程

进程和线程都是由系统来进行创建,JVM通过调用当前系进行开辟进行和线程的操作。

代码语言:javascript复制
import java.io.IOException;

public class ProcessDemo {

    //在Java中如何开启一个进程:运行记事本程序
    public static void main(String[] args) throws IOException {
        //方式1:使用Runtime类的exec方法       
        Runtime runtime = Runtime.getRuntime();
        runtime.exec("notepad");

        //方式2:使用ProcessBuilder的start方法
        ProcessBuilder pb = new ProcessBuilder("notepad");
        pb.start();
    }
}

线程

线程是进程中的内容。它是程序中的控制单元或叫执行路径。线程才是真正去执行的。一个进程可以有多个线程组成,他们分别执行不同的任务。 一个进程至少有一条线程,当线程内有多个进程同时运行时,这种方式 称为并发运行。如:web服务器。线程控制着进程的执行。 执行路径:一个程序从头走到尾就是一个执行路径

线程执行原理:以主线程为例,当执行进程时,进程内的线程开始执行代码。在程序中,内存中的代码都是由线程在执行的。java中的主线程就是main。

进程和线程的区别

1.在开销方面

每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销; 线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。

2.所处环境

在操作系统中能同时运行多个进程(程序); 而在同一个进程(程序)中有多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行)

3.内存分配方面

系统在运行的时候会为每个进程分配不同的内存空间; 而对线程而言,除了CPU外,系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源。

4.包含关系

没有线程的进程可以看做是单线程的,如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的; 线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。

总结

一进程可以同时执行个线程,称多线程。

0 人点赞