day9--多线程与多进程

Posted (野生程序员)

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了day9--多线程与多进程相关的知识,希望对你有一定的参考价值。

    线程:

    什么是线程?

    线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务

    每一个程序的内存是独立的,互相不能直接访问。

    进程:

    以一个整体的形式暴露给操作系统管理,里面包含对各种资源的调用,内存的对各种资源管理的集合就可以称为进程。进程本身是不可以执行的,只是一堆指令,操作系统是线程执行的。

    表面看进程在执行,其实是线程在执行,一个进程至少包含一个线程。

    线程:线程就是可执行的上下文,CPU执行所需要的最小单位。CPU只负责运算。单核的CPU同时只能做一件事情,为什么我们可以切换各种程序,是由于CPU的执行速度很快,在来回切换,让我们看起来程序是执行多个进程。

    操作系统通过PID,进程ID来区分进程。进程标识符,PID。进程能够设置优先级。

    线程是有主线程创建的,primary thread;能够一直创建新的线程,Linux操作系统有一个主线程。

    线程和进程的区别:

    线程和进程比快是没有可比性的。

    1、线程共享内存空间,进程的内存是独立的;

    2、同一个进程的线程之间可以直接交流,两个进程想通信,必须通过一个中间代理来实现;

    3、新的线程容易创建,创建新线程需要对其父进程进行一次克隆;(parent process)

    4、一个线程可以控制和操作同一进程里的其他线程,但是进程只能操作子进程;

    5、线程之间数据可以交流,进程之间是不允许数据交流的。

 

以上是关于day9--多线程与多进程的主要内容,如果未能解决你的问题,请参考以下文章

python多进程与多线程使用场景

python之多线程与多进程

多进程(mutiprocessing)与多线程(Threading)之多线程

多进程与多线程

八.多进程与多线程

多线程与多进程