进程和线程的区别

一、进程
进程概念的提出: 为了并发的执行任务
进程操作系统分配 资源的 最小单位


进程的特点:
进程间的地址空间是互相独立的,所以进程间进行数据交换

时就需要使用IPC(数据需要搬来搬去,除了共享内存以外,其他IPC都需要将数据在内核中拷贝两次)

二、线程
为了在进程内也能够实现并发。
线程是存在于进程内部,而且一般的线程间进行通讯的时候,都是在同一进程内的线程

线程是进程内部的执行分支


既然多个线程是存在于进程中的。
1)所有的线程都共享进程的地址空间。线程访问进程的地址空间就非常方便(线程间进行数据交换就非常方便)
同时:但是,线程间进行 数据同步 就比较麻烦


比较 进程和线程
1、创建一个进程 需要创建一个 PCB(process ctrl block)
2、进程间进行数据交换的时候 需要使用 IPC,这种方式比较的消耗系统资源。
3、创建一个线程 创建一个 TCB(thread ctrl block)
这个TCB 比 PCB要小的多,
因为线程共享的是进程的地址空间,所以新建一个线程的时候,所消耗的资源就比创建一个进程要小的多


=> 多线程能够 提高系统对资源的利用率,提供系统并发能力

ps -eLf
LWP:light weight process(轻量级进程)
线程是一个轻量级的进程
其实 进程本身 也是一个线程


LWP 所对应的数字: 线程的ID


每一个进程都有一个 进程ID PID
每一个进程同时都对应一个 线程ID 
如果一个进程中没有除自己本身外的其他线程,他本身就是
主线程,此时的线程ID = 进程ID
如果一个进程中有其他的线程,进程本身是一个主线程,并且主线程的ID = PID,其他的线程都各自对应一个线程ID


线程的主要目的是 实现在进程内部的并发。
并发的目的是什么?
提高系统资源的利用率,提高系统的并发率。
最直接的目的:要干一件事情,执行一个任务。


一个任务在代码中是如何描述的?使用一个函数来表示的
=》 线程在进程内部使用一个函数来体现的,这个函数我们叫做线程函数。

* 星号:   在操作系统内  任务调度的最小单位是: 线程


进程线程是操作系统中的两个重要概念,它们有以下区别: 1. 进程是指在操作系统中正在运行的一个程序,它是系统分配资源的基本单位;而线程是指进程内部的一个执行单元,它是CPU调度的基本单位。 2. 进程之间相互独立,一个进程崩溃不会影响其他进程的运行;而进程内部的线程共享进程的资源,包括内存、文件、网络连接等,一个线程的崩溃可能会导致整个进程的崩溃。 3. 创建进程的开销比创建线程的开销大,因为进程需要独立的地址空间系统资源;线程的开销相对较小,因为它们共享进程的资源。 4. 进程之间通信比较麻烦,需要使用进程间通信机制;而线程之间通信比较简单,可以通过共享内存等方式实现。 下面给出一个python的例子来说明进程线程区别: 1.创建进程[^1] ```python import os def run_proc(name): print('Child process %s (%s) Running...' % (name, os.getpid())) if __name__ == '__main__': print('Parent process %s.' % os.getpid()) p = Process(target=run_proc, args=('test',)) print('Child process will start.') p.start() p.join() print('Child process end.') ``` 2.创建线程[^2] ```python import threading def run_thread(name): print('Thread %s is running...' % name) if __name__ == '__main__': print('Parent thread %s.' % threading.currentThread().getName()) t1 = threading.Thread(target=run_thread, args=('test',)) t2 = threading.Thread(target=run_thread, args=('test2',)) print('Thread %s will start.' % t1.getName()) print('Thread %s will start.' % t2.getName()) t1.start() t2.start() t1.join() t2.join() print('Thread %s end.' % threading.currentThread().getName()) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值