假设一个程序员,想听歌,但是又想敲代码,于是又:

我听完歌就去敲代码:

#! /usr/bin/env python
#coding=utf-8 import time def matter1(music):
print("我想听这些歌") for i in range(0,len(music)):
print("第" + str(i + 1) + "首歌是:" + str(music[i])) #当前时间
print(time.strftime('%Y%H%M%S',time.localtime()))
#假设每一首歌曲的时间是2秒
time.sleep(2)
print("切换下一首歌...") def matter2(number):
print("我在敲代码") j = 0
while j < number:
print("我准备写入第" + str(j +1) + "行代码")
j = j + 1
#当前时间
print(time.strftime('%Y%H%M%S',time.localtime()))
#假设每写一行代码的时间为1s
time.sleep(1)
print("写下一行代码...") if __name__ == '__main__': start = time.time() #设定我要听的个为
music = ['music1','music2','music3']
#开始听歌
matter1(music) #设定敲代码的行数
number = 5
#开始敲代码
matter2(number) end = time.time()
print("完成的时间:",str(end - start))

结果:

完成的时间: 11.00062894821167

可以改成,一边敲代码一边听歌,那么设计一个多线程,可以让他们同时进行

#! /usr/bin/env python
#coding=utf-8 import time
import threading def matter1(music):
print("我想听歌!!!") for i in range(0,len(music)):
print("第" + str(i+1) + "首歌是:" + str(music[i])) #当前时间是
print(time.strftime('%Y%H%M%S',time.localtime())) #假设每一首歌曲的时间是2s
time.sleep(2) print("切换下一首歌...") def matter2(number):
print("我在敲代码!!!") j = 0
while j < number:
print("我准备写入第" + str(j+1) + "行代码")
j = j+1 #当前时间是
print(time.strftime('%Y%H%M%S',time.localtime())) #假设每写一行代码的时间为1s
time.sleep(1) print("写下一行代码...") if __name__ == '__main__':
#设定我要听的歌为
music = ["music1","music2","music3"] #设定我要敲代码的行数
number = 5 threads = [] thing1 = threading.Thread(target=matter1,args=(music,))
threads.append(thing1) thing2 = threading.Thread(target=matter2,args=(number,))
threads.append(thing2) #开始时间
startTime = time.time() #写个for让两件事情都进行
for thing in threads:
#setDaemon为主线程启动了线程matter1和matter2
#启动也就是相当于执行了这个for循环
thing.setDaemon(True)
thing.start() #为了防止子线程还没结束主线程就结束的意外情况,在程序里面加个join
#子进程没结束前,主线程会被卡在这里
thing1.join()
thing2.join() #结束时间
endTime = time.time()
print("完成的时间为:",str(endTime-startTime))

结果:

完成的时间为: 6.000343084335327

封装成类的形式

#! /usr/bin/env python
#coding=utf-8 import time
import threading class MyThread(threading.Thread):
def __init__(self,func,args,name=''):
threading.Thread.__init__(self)
self.name = name
self.func = func
self.args = args def run(self):
#某某线程要开始了
print(self.name + "开始了#######") if self.name == "听歌线程":
matter1(music)
elif self.name == "打码线程":
matter2(number)
print(self.name + "结束了########") def matter1(music):
for i in range(0,len(music)):
print("第" + str(i+1) + "首歌是:" + str(music[i]))
#假设每一首歌曲的时间是2s
time.sleep(2)
print("切换下一首歌...") def matter2(number):
j = 0
while j < number:
print("我准备写入第" + str(j+1) + "行代码")
j = j+1
#假设每一行代码的时间为1s
time.sleep(1)
print("写下一行代码...") if __name__ == '__main__':
#设定我要听的歌曲为
music = ['music1','music2','music3'] #设定我要打码的行数
number = 5 #开始时间
start = time.time() thing1 = MyThread(matter1,music,"听歌线程")
thing2 = MyThread(matter2,number,"打码线程") thing1.start()
thing2.start() thing1.join()
thing2.join() #结束时间
end = time.time()
print("完成的时间为:",str(end - start))

结果:

完成的时间为: 6.001343011856079

python-多线程趣味的更多相关文章

  1. python多线程学习记录

    1.多线程的创建 import threading t = t.theading.Thread(target, args--) t.SetDeamon(True)//设置为守护进程 t.start() ...

  2. python多线程编程

    Python多线程编程中常用方法: 1.join()方法:如果一个线程或者在函数执行的过程中调用另一个线程,并且希望待其完成操作后才能执行,那么在调用线程的时就可以使用被调线程的join方法join( ...

  3. Python 多线程教程:并发与并行

    转载于: https://my.oschina.net/leejun2005/blog/398826 在批评Python的讨论中,常常说起Python多线程是多么的难用.还有人对 global int ...

  4. python多线程

    python多线程有两种用法,一种是在函数中使用,一种是放在类中使用 1.在函数中使用 定义空的线程列表 threads=[] 创建线程 t=threading.Thread(target=函数名,a ...

  5. python 多线程就这么简单(转)

    多线程和多进程是什么自行google补脑 对于python 多线程的理解,我花了很长时间,搜索的大部份文章都不够通俗易懂.所以,这里力图用简单的例子,让你对多线程有个初步的认识. 单线程 在好些年前的 ...

  6. python 多线程就这么简单(续)

    之前讲了多线程的一篇博客,感觉讲的意犹未尽,其实,多线程非常有意思.因为我们在使用电脑的过程中无时无刻都在多进程和多线程.我们可以接着之前的例子继续讲.请先看我的上一篇博客. python 多线程就这 ...

  7. python多线程监控指定目录

    import win32file import tempfile import threading import win32con import os dirs=["C:\\WINDOWS\ ...

  8. python多线程ssh爆破

    python多线程ssh爆破 Python 0x01.About 爆弱口令时候写的一个python小脚本,主要功能是实现使用字典多线程爆破ssh,支持ip表导入,字典数据导入. 主要使用到的是pyth ...

  9. 【python,threading】python多线程

    使用多线程的方式 1.  函数式:使用threading模块threading.Thread(e.g target name parameters) import time,threading def ...

  10. <转>Python 多线程的单cpu与cpu上的多线程的区别

    你对Python 多线程有所了解的话.那么你对python 多线程在单cpu意义上的多线程与多cpu上的多线程有着本质的区别,如果你对Python 多线程的相关知识想有更多的了解,你就可以浏览我们的文 ...

随机推荐

  1. 【elasticsearch】安装合集

    [elasticsearch](1)centos7 使用yum安装elasticsearch 2.X [elasticsearch](2)centos7 超简单安装elasticsearch 的监控. ...

  2. 【Postman】接口测试工具:在谷歌浏览器安装插件方法以及使用说明

    安装插件方法: <如何在谷歌浏览器chrome中离线安装.crx扩展程序的三种方法?> <postman chrome插件的安装与使用> 下载地址:http://www.cnp ...

  3. 源码安装Apache,报错:Cannot use an external APR with the bundled APR-util

    一般在第一次源码安装是没有问题的,在版本变化情况下在次源码安装可能会遇到此问题: apache2.0.x与apache2.2.x在apr有很大区别,前者为依赖公用apr,后者依赖于自身的apr.一般前 ...

  4. c语言三元组

    // Triplet.cpp : 定义控制台应用程序的入口点.//#include "stdio.h"#include "stdlib.h"#define OK ...

  5. Windows下安装appium桌面版和命令行版

    安装appium桌面版和命令行版   一 桌面版(打开很慢,常用于辅助元素定位) 1.官网下载window版本:  github search appium desktop download late ...

  6. 【BZOJ4033】[HAOI2015]树上染色 树形DP

    [BZOJ4033][HAOI2015]树上染色 Description 有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑色,并将其他的N-K个点染 ...

  7. java ScriptEngine 使用

    Java SE 6最引人注目的新功能之一就是内嵌了脚本支持.在默认情况下,Java SE 6只支持JavaScript,但这并不以为着Java SE 6只能支持JavaScript.在Java SE ...

  8. 不怕慢 就怕站 不怕单线程 不怕 裸露ip

    import sys import os import requests import threading from time import sleep from bs4 import Beautif ...

  9. python 列表中字符串排序故事一则

    a = ["bca","cab","abc"] 有时候需要对列表排序 如果是对列表中整个元素 直接用sort()排序 如果想按元素的某一段排 ...

  10. 【Robot Framework】---- Robot Framework简介、特点、RIDE

    Robot Framework简介.特点.RIDE 一.简介.特点. Robot Framework是一款python编写的功能自动化测试框架.具备良好的可扩展性,支持关键字驱动,可以同时测试多种类型 ...