一、什么是进程?
进程就是指正在执行的程序的实例。每个进程都有自己独立的内存空间,包括代码、数据、堆栈等。
1.1 进程的特点
独立性:每个进程都是独立运行的实体,不受其他进程的影响。
资源分配:每个进程拥有自己的资源分配,如内存空间等。
安全性:进程之间相互隔离,一个进程无法直接访问另一个进程的内存空间。
可靠性: 进程之间的错误不会相互影响,一个进程崩溃不会导致整个系统崩溃。
二、什么是线程?
线程是进程中的实体,是处理器调度的基本单位。一个进程可以包含多个线程,这些线程共享进程的资源,如内存空间、文件描述符等。
2.1 线程的特点
共享性:线程共享同一个进程的资源,可以方便地共享数据。
轻量级:相比进程,线程的创建和销毁开销更小。
效率:线程之间切换的开销比进程小,适合需要频繁切换的任务
三、进程和线程的关系
一个进程可以包含多个线程,这些线程共享进程的资源 。
线程是进程中的执行单元,多线程可以充分利用多核处理器的性能。
进程之间相互独立,线程之间共享内存空间,需要喝醉线程之间的同步与互斥。
四、示例
下面我们使用Java实现线程并发执行的任务
public class MultiThreadExample {
public static int fibonacci(int n) {
if (n <= 0) {
return 0;
} else if (n == 1) {
return 1;
} else {
return fibonacci(n - 1) + fibonacci(n - 2);
}
}
public static void main(String[] args) {
System.out.println("线程开始");
// 创建两个线程
Thread t1 = new Thread(() -> {
System.out.println("fib = " + fibonacci(10));
});
Thread t2 = new Thread(() -> {
System.out.println("fib = " + fibonacci(20));
});
// 启动线程
t1.start();
t2.start();
// 等待线程完成
try {
t1.join();
t2.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("线程结束");
}
}