设为首页 收藏本站
查看: 557|回复: 0

[经验分享] python 多线程 和 多进程

[复制链接]

尚未签到

发表于 2017-4-30 10:08:41 | 显示全部楼层 |阅读模式
  单线程例子:


#!/usr/bin/python
# -*- coding:UTF-8 -*-
# Name: danxiancheng.py
import time
import threading
def loop(num,sec):
print 'loop %s start: ....' % num, time.strftime('%Y-%M-%d %H:%m:%S')
time.sleep(sec)
print 'loop %s stop: .....' % num, time.strftime('%Y-%M-%d %H:%m:%S')

def main():
print '\nStarting: ........', time.strftime('%Y-%M-%d %H:%m:%S'), '\n'
mysec = [3,5,6,8]
for i in range(len(mysec)):
loop(i,mysec)
print '\nAll DONE: ........', time.strftime('%Y-%M-%d %H:%m:%S'), '\n'
if __name__=='__main__':
main()
   打印结果:
  [iyunv@xhu_node3 ~]# python singlethread.py


Starting: ........ 2012-33-27 05:12:12


loop 0 start: .... 2012-33-27 05:12:12

loop 0 stop: ..... 2012-33-27 05:12:15

loop 1 start: .... 2012-33-27 05:12:15

loop 1 stop: ..... 2012-33-27 05:12:20

loop 2 start: .... 2012-33-27 05:12:20

loop 2 stop: ..... 2012-33-27 05:12:26

loop 3 start: .... 2012-33-27 05:12:26

loop 3 stop: ..... 2012-33-27 05:12:34


All DONE: ........ 2012-33-27 05:12:34


[iyunv@xhu_node3 ~]#
  多线程的例子:


#!/usr/bin/python
# -*- coding:UTF-8 -*-
# Name: duoxiancheng.py
import time
import threading
def loop(num,sec):
print 'loop %s start: ....' % num, time.strftime('%Y-%M-%d %H:%m:%S')
time.sleep(sec)
print 'loop %s stop: .....' % num, time.strftime('%Y-%M-%d %H:%m:%S')

def main():
print '\nStarting: ........', time.strftime('%Y-%M-%d %H:%m:%S'), '\n'
mysec = [3,5,6,8]
mythreads = [threading.Thread(target=loop,args=(i,mysec)) for i in range(len(mysec))]
for i in mythreads:
i.start()
for i in mythreads:
i.join()
print '\nAll DONE: ........', time.strftime('%Y-%M-%d %H:%m:%S'), '\n'
if __name__=='__main__':
main()
   执行结果:
  [iyunv@xhu_node3 ~]# python mutithread.py


Starting: ........ 2012-36-27 05:12:19


loop 0 start: .... 2012-36-27 05:12:19

loop 1 start: .... 2012-36-27 05:12:19

loop 2 start: .... 2012-36-27 05:12:19

loop 3 start: .... 2012-36-27 05:12:19

loop 0 stop: ..... 2012-36-27 05:12:22

loop 1 stop: ..... 2012-36-27 05:12:24

loop 2 stop: ..... 2012-36-27 05:12:25

loop 3 stop: ..... 2012-36-27 05:12:27


All DONE: ........ 2012-36-27 05:12:27
  结论:

  可以看到单线程中的两个循环, 只有一个循环结束后另一个才开始。而多线程则是进程内所有线程一起执行,同步任务。

  首先创建了n个线程,并将其存放到mythreads列表中,这里用到的是给Thread类传递了函数,第一个for循环是让两个线程开始执行。第二个for循环再让每个线程分别调用join函数,使程序挂起,直至相应线程都执行结束。
  多进程例子:
  test.py

#!/usr/bin/python
import time
import os  
from os import environ

class MyClass:
def __init__(self):
self.aa = 1
def getA(self):
return environ['FOO']
def subA(self):
self.aa += 1

if __name__ == '__main__':
pass
   pro.py

#!/usr/bin/python
import os
import sys
import time, datetime, traceback
from os import environ
from multiprocessing import Process
from test import MyClass
def create_compute(hostname):
try:
environ['FOO'] = hostname
a = MyClass()
print a.getA()
except Exception as e:
print e
traceback.print_exc()
if __name__ == '__main__':
plist = []
for i in 4,5:
p = Process(target = create_compute, args = ('node'+str(i),))
plist.append(p);  
p.start()
for p in plist:  
p.join()
   执行结果:
  [iyunv@xhu_node3 ~]# python pro.py

node4

node5

[iyunv@xhu_node3 ~]#
  结论:
  两个进程中设置的环境变量 互不影响

多进程:

http://blog.csdn.net/inte_sleeper/article/details/6741963





多线程:




http://blog.chinaunix.net/uid-16362696-id-2746820.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-371092-1-1.html 上篇帖子: 50个很棒的Python模块 下篇帖子: 也谈 Python 的中文编码处理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表