Java面试——操作系统篇
1.进程线程的区别
-
定义:
- 进程:进程是操作系统进行资源分配和调度的一个独立单位。它是应用程序运行的实例,拥有独立的内存空间。
- 线程:线程是进程中的一个实体,是被系统独立调度和分派的基本单位。线程自身基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如执行栈),但它可以与同属一个进程的其他线程共享进程所拥有的全部资源。
-
资源拥有:
- 进程:拥有独立的内存地址空间。
- 线程:与同一进程内的其他线程共享内存地址空间。
-
创建和管理开销:
- 进程:创建和管理开销较大。
- 线程:创建和管理开销较小。
-
独立性:
- 进程:进程间的操作相互独立,一个进程的崩溃不会直接影响其他进程。
- 线程:同一进程下的线程间操作相互依赖,一个线程的崩溃可能影响整个进程。
-
通信方式:
- 进程:需要使用进程间通信(IPC)机制。
- 线程:可以直接读写共享数据段,通信更简单。
-
上下文切换:
- 进程:上下文切换开销较大。
- 线程:上下文切换开销较小。
-
执行流:
- 进程:是程序执行的独立实体。
- 线程:是进程中执行的子实体,是被系统独立调度的基本单位。