#!/usr/bin/env python
# -*- coding:utf-8 -*- import os
import time,random
import threading # 1-进程说明
# 进程是软件、程序执行的一个实例,每个运行的程序,可创建多个进程,但至少包含1个进程,进程提供程序执行时需要的所有资源
# 进程可以包含线程,每个进程至少包含一个线程
# 进程启动时,会创建1个线程即主线程,然后通过主线程创建需要的其他子线程 # 2-线程说明
# 线程是进程中的一个实体,为程序执行的最小单元,也是可被独立分派和执行基本单位
# 线程由线程ID,指令指针(PC)、寄存器集合、堆栈组成
# 线程不独占资源,可与同属同一进程的其他线程共享进程中的资源
# 每个应用程序,至少包含一个进程和一个线程
# 单个程序允许多个线程,完成不同的分工,被称为多线程处理 # 线程即执行上下文,1个CPU执行时所需的一串指令 # 3-多任务说明
# 执行多任务可通过 1-开启多个进程,每个进程包含1个线程,2-开启1个进程,进程中有多个线程,3-多个进程,每个进程包含多个线程
# 子进程返回0,父进程返回之进程ID,1个父进程可以fork很多子进程,父进程需记录每个子进程的ID,子进程通过getppid()得到父进程ID # threading 提供线程的各类操作
# 实现多线程可通过2种方式
# 方法1:继承Thread 通过start启动 并实现run方法
# 方法2:实例化threading.Thread类,并将线程要执行的任务函数做为参数传给线程
# start方法 启动线程并等待CPU调度 run方法 线程被CPU调度后自动执行的方法 # 启动线程方法1 继承Thread
class myThread(threading.Thread):
def __init__(self,thread_name):
super(myThread,self).__init__(name=thread_name) def run(self):
print("%s线程正在运行中..."%self.name) def show(targs):
time.sleep(1)
print("thread"+str(targs)+"\tis running....") # 启动线程方法2 实例化threading.Thread类
# threading.Thread(self, group=None, target=None, name=None,
# args=(), kwargs=None, *, daemon=None)
# group 用于扩展,target 可调用对象,在线程启动后执行
# name 线程名字 默认为"Thread-N"
# args 参数列表 kwargs 关键字参数 调用target时的参数
# daemon 线程启动方式 前台还是后台,默认为False 即前台线程
# daemon=False 前台线程:主线程执行过程中,前台线程也在执行,主线程执行完毕,等待前台线程执行完毕,程序才停止
# daemon=True 后台线程:主线程执行过程中,后台线程也在执行,主线程执行完毕,后台线程不论执行是否结束,程序也会停止 # 如果希望主线程等待子线程执行完毕后,程序才结束
# 可通过将子线程加入到主线程中 如,使用join方法,或者设置子线程为主现成的守护线程 setDaemon(True) # 程序执行时,主线程执行完毕,再等待子线程执行完后,程序才执行完毕 # 多核CPU用多进程 多进程的执行效率高于多线程
# CPU密集型任务使用多进程 IO密集型任务使用多线程 # join方式 在线程启动后,设置 将子线程加入 主线程 join()
def doWaiting():
print('start waiting:', time.strftime('%H:%M:%S'))
time.sleep(3)
print('stop waiting', time.strftime('%H:%M:%S')) t = threading.Thread(target=doWaiting)
t.start()
# 确保线程t已经启动 time.sleep(1)
print('start join')
# 将一直堵塞,直到t运行结束。
t.join()
print('end join') # setDaemon方式 线程启动前,设置setDaemon=True
def thread_fun():
print(threading.current_thread().getName(),"开始工作")
time.sleep(2)
print("子线程结束工作") for i in range(5):
t=threading.Thread(target=thread_fun,)
t.setDaemon(True)
t.start() print("主线程开始")
time.sleep(2)
print("主线程结束") # 活跃线程数
print(threading.active_count()) # daemon方式 线程启动前,设置daemon=False
def thread_fun():
print(threading.current_thread().getName(),"开始工作")
time.sleep(2)
print("子线程结束工作") for i in range(5):
t=threading.Thread(target=thread_fun,daemon=False)
t.start() print("主线程开始")
time.sleep(2)
print("主线程结束") # 活跃线程数
print(threading.active_count()) if __name__=='__main__':
for i in range(5):
# 方法1
myThread("thread-"+str(i)).start() # 方法2
t=threading.Thread(target=show,args=(i,))
t.start()

python3线程介绍01(如何启动和调用线程)的更多相关文章

  1. C# 委托高级应用----线程——创建无阻塞的异步调用(一)

    前言 本文大部分内容来自于mikeperetz的Asynchronous Method Invocation及本人的一些个人体会所得,希望对你有所帮助.原英文文献可以在codeproject中搜索到. ...

  2. 谈.Net委托与线程——创建无阻塞的异步调用(一)

    前言 本文大部分内容来自于mikeperetz的Asynchronous Method Invocation及本人的一些个人体会所得,希望对你有所帮助.原英文文献可以在codeproject中搜索到. ...

  3. python3线程介绍02(线程锁的介绍:互斥、信号、条件、时间、定时器)

    #!/usr/bin/env python# -*- coding:utf-8 -*- import threadingimport timeimport random # 1-互斥锁 Lock 同一 ...

  4. java线程介绍

    文章讲解要点 1.线程创建几种方式2.线程常见设置方法,包括优先级.优先级休眠.停止等3.多线程间的数据交互与锁机制4.项目源码下载   线程介绍.png 一.线程创建方式 常见的线程创建方法以下三种 ...

  5. JVM 内部运行线程介绍

    转(http://club.alibabatech.org/article_detail.htm?articleId=4) JVM 内部运行线程介绍 作者:蒋家佳/觉梦(支付宝开发工程师) 浏览量: ...

  6. Java多线程系列--“JUC线程池”01之 线程池架构

    概要 前面分别介绍了"Java多线程基础"."JUC原子类"和"JUC锁".本章介绍JUC的最后一部分的内容——线程池.内容包括:线程池架构 ...

  7. MFC启动和关闭线程

    1. 启动线程: CWinThread* AfxBeginThread( 线程函数,this ); 2.通常导致线程终止的两种情况是:控制函数退出或不允许线程完成运行.如果字处理器使用后台打印线程,若 ...

  8. java jstack dump 线程 介绍 解释

    最近抽时间把JVM运行过程中产生的一些线程进行了整理,主要是围绕着我们系统jstack生成的文件为参照依据.  前段时间因为系统代码问题,造成性能到了天花板,于是就dump了一份stack出来进行分析 ...

  9. Java并发——线程介绍

    前言: 互联网时代已经发展到了现在.从以前只考虑小流量到现在不得不去考虑高并发的问题.扯到了高并发的问题就要扯到线程的问题.你是否问过自己,你真正了解线程吗?还是你只知道一些其他博客里写的使用方法.下 ...

随机推荐

  1. C3算法之我见

    C3算法说到底就是merge算法,看了一些帖子,总结说得莫名其妙,大家也是抄来抄去,我试着用自己的话来把这个东西怎么操作的说清楚.当然了我也要抄一些别人的,但是我会 尽量把我认为别人没有讲清楚的那一部 ...

  2. H5切换至后台页面

    先说重点,试了很多种方法,这个真实有效 var reLoadLeftTime = false ;//监听浏览器当前页面是否被激活的事件var hiddenProperty = 'hidden' in ...

  3. git学习--clone和pull

    clone:从远程服务器克隆一个一模一样的版本库到本地,复制的是整个版本库.(clone是将一个库复制到你的本地,是一个本地从无到有的过程) pull:从远程服务器获取到一个branch分支的更新到本 ...

  4. 读经典——《CLR via C#》(Jeffrey Richter著) 笔记_友元程序集

    [应用场景] 程序集A访问程序集B定义的Internal访问类型的类的成员. [使用方式] 在构建程序集B的时候,引入System.Runtime.CompilerServices,以此来添加Inte ...

  5. 奇偶交错排列(DFS)

    Description 一个1-n1−n的排列满足所有相邻数字奇偶性不同,那么称该排列为奇偶交错排列. 按字典序输出1-n1−n的所有奇偶交错排列. Input 输入一个整数n( 2 \le n \l ...

  6. Codeforces-C-Nice Garland(枚举+暴力)

    You have a garland consisting of nn lamps. Each lamp is colored red, green or blue. The color of the ...

  7. datatables通过ajax调用渲染数据,怎么根据数据给td添加class

    html: <table id="table8" cellpadding="0" cellspacing="0" border=&qu ...

  8. Jenkins自动化CI CD流水线之5--pipeline

    一.概览 二.安装 在对jenkins进行初始化安装时,默认已经安装了jenkins的相关插件,如下图所示: 三.实操 新建任务: 编写pipeline脚本: 我们可以借助流水线语法去做. test流 ...

  9. 6 GPath

    1       GPath GPath是Groovy的表达式语言,类似xml的XPath.而二者的不同在于,GPath表达式可以应用于处理POJOs或者处理xml. 例如:a.b.c语句等同于a.ge ...

  10. Outlook 2010中263邮箱客户端设置

    Outlook 2010中263邮箱客户端设置 1.首次添加电子邮箱账户:打开outlook,在账户设置和服务中分别选择:“手动配置服务器设置或其他服务器类型”,“Internet电子邮件” 2.在i ...