1.线程是程序里面最小的执行单元。

2.进程是资源的集合。

  线程是包含在进程里面的,一个进程可以有多个线程,但只要要有一个线程。

一.多线程,就是N个线程一起干活:

  1.传统方式,串行,循环5次需要15s:

import threading,time

def run():
  time.sleep(3) #干活需要3s
print('哈哈哈') for i in range(5): #串行
run()

  2.使用多线程并发的方式,节省时间:

import threading,time

def run():
  time.sleep(3) #干活需要3s
print('哈哈哈')
for i in range(5):#并发
  t = threading.Thread(target=run) #实例化了一个线程,其中target=执行的函数名
  t.start() #启动线程

举例:多线程爬虫,比较下并发和串行的时间:

 串行方式:

import threading,time,requests

urls = {
'baidu':'http://www.baidu.com',
'hao123':'http://www.hao123.com',
'taobao':'https://www.taobao.com/'
} def down_html(file_name,url):
res = requests.get(url).content #返回二进制内容
open(file_name+'.html','wb').write(res) #因此打开的时候,用wb二进制打开 用串行方式
start_time = time.time()
for k,v in urls.items():
down_html(k,v)
end_time = time.time() run_time = end_time - start_time
print('下载总共花了%s的时间'%run_time)

串行结果:

并行方式:这种方式计算的并发时间是不准确的,因为在运行程序时默认先运行主线程,其他线程只是开始运行(下载网页)并不一定结束(而一个进程中的多个线程都是相互独立的。)主线程负责定义函数,启动其他线程等。因此,最终并行运行的结果时间,仅仅是主线程的运行时间。

   主线程
默认有个主线程
子线程:
主线程启动子线程
import threading,time,requests

urls = {
'baidu':'http://www.baidu.com',
'hao123':'http://www.hao123.com',
'taobao':'https://www.taobao.com/'
} def down_html(file_name,url):
res = requests.get(url).content #返回二进制内容
open(file_name+'.html','wb').write(res) #因此打开的时候,用wb二进制打开 #用并行方式
start_time = time.time()
for k,v in urls.items():#因为urls里有3个Key,因此会启动3个线程
t = threading.Thread(target=down_html,args=(k,v)) #使用多线程调用参数时,必须用args=xx才能传参
t.start()
end_time = time.time()
run_time = end_time - start_time
print('下载共花了%s时间'%run_time)

并行结果:

线程等待:.join()-----实现并发

下面程序运行流程:

主线程负责启动5个子线程,把每个线程放在threads list里,然后等待所有线程等待完毕后,再执行end_time = time.time()语句,实现最后计算所有线程都结束的并发时间。

主线程
默认有个主线程
子线程:
主线程启动子线程
import threading,time
def run():
time.sleep(3):
print('哈哈哈哈') start_time = time.time()
threads=[] #存放启动的5个子线程
for i in range(5):
t = threading.Thread(target=run) #实例化
t.start() #启动线程
threads.append(t) #启动后将子线程加入列表 for t in threads: #主线程循环等待5个子线程执行结束
t.join() #循环等待,等所有线程执行完毕后,再执行下一句,即实现计算所有并发时间
end_time = time.time()
print('run_time',end_time-start_time)

运行结果:并发时间:(这个时间是准确的)

多线程threading初识,线程等待的更多相关文章

  1. c/c++ 多线程 多个线程等待同一个线程的一次性事件

    多线程 多个线程等待一个线程的一次性事件 背景:从多个线程访问同一个std::future,也就是多个线程都在等待同一个线程的结果,这时怎么处理. 办法:由于std::future只能被调用一次get ...

  2. 多线程threading初识二--多线程等待

    .join() :子线程等待主线程 下面程序运行流程: 主线程负责启动5个子线程,把每个线程放在threads list里,然后等待所有线程等待完毕后,再执行end_time = time.time( ...

  3. python中多进程multiprocessing、多线程threading、线程池threadpool

    浅显点理解:进程就是一个程序,里面的线程就是用来干活的,,,进程大,线程小 一.多线程threading 简单的单线程和多线程运行:一个参数时,后面要加逗号 步骤:for循环,相当于多个线程——t=t ...

  4. Java多线程5:线程等待与唤醒

    原文:http://www.cnblogs.com/skywang12345/p/3479224.html wait(),notify(), notifyAll()等方法介绍在Object.java中 ...

  5. 12、多线程:Threading、守护线程

    线程与进程: 线程对于进程来说,就好似工厂里的工人,分配资源是分配到工厂,工人再去处理. 线程是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属 ...

  6. 多进程 multiprocessing 多线程Threading 线程池和进程池concurrent.futures

    multiprocessing.procsess 定义一个函数 def func():pass 在if __name__=="__main__":中实例化 p = process( ...

  7. Java多线程系列--“基础篇”05之 线程等待与唤醒

    概要 本章,会对线程等待/唤醒方法进行介绍.涉及到的内容包括:1. wait(), notify(), notifyAll()等方法介绍2. wait()和notify()3. wait(long t ...

  8. java 多线程—— 线程等待与唤醒

    java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...

  9. c/c++ 多线程 一个线程等待某种事件发生

    多线程 一个线程等待某种事件发生 背景:某个线程在能够完成其任务之前可能需要等待另一个线程完成其任务. 例如:坐夜间列车,为了能够不坐过站, 1,整夜保持清醒,但是这样你就会非常累,不能够睡觉. 2, ...

随机推荐

  1. django前端分页小组件

    # -*- coding:utf-8 -*- from django.utils.safestring import mark_safe class Page(object): def __init_ ...

  2. oracle数据库中的存储函数

    oracle中的存储函数,和系统内的函数类似,可以像调用系统函数一样调用存储函数.它与存储过程的唯一区别就是存储过程没有return返回值,存储函数可以与存储过程互换,存储函数可以在存储过程中调用. ...

  3. background的水平条纹和斜向条纹

    水平条纹: <div id="div1"> </div> linear-gradient属性 #div1{ width: 100px; height: 10 ...

  4. 03python面向对象编程3

    案例学习 # notebook.pyimport datetime # Store the next available id for all new notes last_id = 0 class ...

  5. vim查找和替换

    https://www.cnblogs.com/huxinga/p/7942194.html %s/husband/丈夫/g

  6. flask之日志的配置

    1. 项目中,日志和配置文件都是单独在一个文件夹中,一般log文件夹和config文件夹,两个文件夹和manage.py在同一个目录下. 2. 配置日志前,先给flask装上script脚本扩展,Fl ...

  7. MySQL技巧--伪哈希索引

    哈希索引 哈希索引就是通过一个哈希函数计算出某个key的hash值,并以这个hash值去找到目标数据.例如:对于数据库的一行数据,对其主键进行hash运算,得到一个地址,这个地址指向这行记录的存储地址 ...

  8. Markdown的使用和计算机基础

    TOC] 一级标题 这不是开玩笑 你问我为什么? 粗的才好(滑稽) 什么!明明有人推我 ==一闪一闪亮晶晶== 我上面有人^人在这^ water?H~2~O(下标) hello world! hell ...

  9. 《SaltStack技术入门与实践》—— Mine

    Mine 本章节参考<SaltStack技术入门与实践>,感谢该书作者: 刘继伟.沈灿.赵舜东 Mine是SaltStack收集Minion数据存储到Master的一个组件,它的功能与Gr ...

  10. 【leetcode】838. Push Dominoes

    题目如下: 解题思路:本题题目中有一点要求很关键,“we will consider that a falling domino expends no additional force to a fa ...