python多进程和多线程---(自学中,坚持更新)

Posted

tags:

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

首先我们知道进程和线程最明显的区别是:

多进程环境中,每个进程有自己的进程数据,各个进程数据之间是相互独立的。一个进程可以有多个线程,多个线程共享该进程的数据。

 

#-*- coding:utf-8 -*-

import os

from nt import getpid

 

print("current id: %d" %getpid())

输出

current id: 17452

 

创建进程:

创建进程,linux下用fork,和linux环境下C编程的fork函数一样,对于父进程而言,返回的是子进程的pid,对于子进程而言,返回的是0

from os import *

 

print("current id: %d" %getpid())

 

pid = fork()

if pid == 0:

    print("i am the child process:%d"  %getpid())

else:

print("i am parent process, my pid is %d, child process %d" %getpid(), pid)

 

python是个夸平台的语言,因此在windows下,python的multiprocessing模块可以实现多进程编程。

下面是个简单的例子

from multiprocessing import Process

from nt import getpid

 

 

def my_proc():

    print(‘i am the proc, pid(%d)‘ %getpid())

 

if __name__==‘__main__‘:

    print(‘Parent process %s.‘ %getpid())

   

    p = Process(target=my_proc)

    print(‘Process will start.‘)

    p.start()

    p.join()

    print(‘Process end.‘)

以上是关于python多进程和多线程---(自学中,坚持更新)的主要内容,如果未能解决你的问题,请参考以下文章

python 多进程和多线程配合

Python第四周之多线程和多进程之线程加锁五车争霸赛

python 多线程和多进程

python(33)多进程和多线程的区别

Python基础14 - 多线程和多进程

多进程和多线程有啥区别?