首页 > 代码库 > python多进程和多线程---(自学中,坚持更新)

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多进程和多线程---(自学中,坚持更新)