线程与进程的区别

简介: 面试中常见问题线程与进程的区别解答参考Java并发编程实战,从并发历史的角度进行解读。 最初计算机是单任务的,程序拥有计算机所有资源。

面试中常见问题

  1. 线程与进程的区别

解答

  1. 参考Java并发编程实战,从并发历史的角度进行解读。
    最初计算机是单任务的,程序拥有计算机所有资源。
    为了能够实现多任务,可以让不同的程序在不同的进程中进行,操作系统为每个进程分配独立的资源:内存,文件句柄等。进程之间的通信依靠:套接字,信号处理器,共享内存,信号量及文件等粗粒度的方式进行。
    线程可以看做更细粒度的进程,一个进程可以启动多个线程,多个线程共享这个进程的资源:内存,文件句柄等,每个线程维护独立的程序计数器,栈,局部变量等。由于一个进程的多个线程共享进程的内存空间,因此多个线程能访问同一变量,并在同一堆上分配对象,这使得线程之间的通信更加简单,同时由于共享内存的存在也使得多线程需要同步机制来确保安全性。
    所以对于需要进行大量通信的场景适合多线程来提高效率,而只需要少量通信的情况适合使用多进程来提高安全性。
目录
相关文章
|
2天前
|
Unix Linux 调度
linux线程与进程的区别及线程的优势
linux线程与进程的区别及线程的优势
|
4天前
|
Java 调度
【Java多线程】对进程与线程的理解
【Java多线程】对进程与线程的理解
11 1
|
13天前
|
调度
线程和进程的区别?
线程和进程的区别?
|
15天前
|
调度 Python 容器
【python】-详解进程与线程
【python】-详解进程与线程
|
16天前
|
安全 Java
【JAVA】线程的run()和start()有什么区别?
【JAVA】线程的run()和start()有什么区别?
|
19天前
|
运维 监控 Unix
第十五章 Python多进程与多线程
第十五章 Python多进程与多线程
|
4天前
|
存储 Linux Shell
Linux:进程等待 & 进程替换
Linux:进程等待 & 进程替换
29 9
|
4天前
|
存储 Linux C语言
Linux:进程创建 & 进程终止
Linux:进程创建 & 进程终止
24 6
|
3天前
|
存储 安全 Linux
【Linux】详解进程通信中信号量的本质&&同步和互斥的概念&&临界资源和临界区的概念
【Linux】详解进程通信中信号量的本质&&同步和互斥的概念&&临界资源和临界区的概念
|
3天前
|
Linux C++
【Linux】详解进程程序替换
【Linux】详解进程程序替换