线程执行的顺序是不确定,可以通过适当的延时,保证某一线程先执行

基础语法

# 多线程的使用方式
import threading def test1():...
# 如果创建Thread时执行的函数,运行结束,那么意味着,这个子线程结束了 def test2():... def main():
t1 = threading.Thread(target=test1)
t2 = threading.Thread(target=test2) t1.start()
t2.start() print(threading.enumerate()) if __name__ == '__main__':
main()

比较复杂的过程,通过类继承Thread类完成创建线程

import threading
import time class MyThread(threading.Thread):
def fun(self):
for i in range(5):
time.sleep(1)
print("[%s]" % i) if __name__ == '__main__':
t = MyThread()
t.start() # start() 调用 self.run() , 涉及调用其它方法,到run函数中调用

多线程全局变量的共享

在一个函数中对全局变量进行修改的时候,到底是否需要使用global进行说明要看是否对全局变量的执行指向进行了修改,

如果修改了执行,即让全局变量指向了一个新的地方,那么必须使用global

如果,仅仅是修改了指向的空间中的数据,此时不必使用global

# 无参
import threading
import time g_num = 100 def test1():
global g_num
g_num += 1
print("--------in test1 g_num=%d--------" % g_num) def test2():
print("--------in test2 g_num=%d--------" % g_num) def main():
t1 = threading.Thread(target=test1)
t2 = threading.Thread(target=test2) t1.start()
time.sleep(1) t2.start()
time.sleep(1) print("--------in main g_num=%d--------" % g_num) if __name__ == '__main__':
main() # 带参
import threading
import time g_num = 100 def test1(temp):
temp.append(33)
print("--------in test1 g_nums=%s--------" % str(temp)) def test2(temp):
print("--------in test2 g_nums=%s--------" % str(temp)) g_nums = [11,22] def main():
# target 去哪个函数执行代码
# args 带着什么过去的
t1 = threading.Thread(target=test1, args=(g_nums,))
t2 = threading.Thread(target=test2, args=(g_nums,)) t1.start()
time.sleep(1) t2.start()
time.sleep(1) print("--------in main g_nums=%s--------" % str(g_nums)) if __name__ == '__main__':
main()

多线程任务的资源竞争

import threading
import time g_num = 0 def test1(num):
global g_num
for i in range(num):
g_num += 1
print("----in test1 g_num=%d----" % g_num) def test2(num):
global g_num
for i in range(num):
g_num += 1
print("----in test2 g_num=%d----" % g_num) def main():
t1 = threading.Thread(target=test1, args=(1000000,))
t2 = threading.Thread(target=test2, args=(1000000,)) t1.start()
t2.start() time.sleep(5) print("----in main gnum=%d----" % g_num) if __name__ == '__main__':
main()
"""
----in test1 g_num=1188472----
----in test2 g_num=1319841----
----in main g_num=1319841----
"""

互斥锁,避免资源竞争

import threading
import time g_num = 0 def test1(num): global g_num
# 上锁,如果之前没有被上锁,那么此时,上锁成功
# 如果上锁之前,已经被上锁了,那么此时会阻塞在这里,直到这个锁被解开为止
mutex1.acquire()
for i in range(num):
g_num += 1
mutex1.release()
print("----in test1 g_num=%d----" % g_num) def test2(num):
global g_num
mutex1.acquire()
for i in range(num):
g_num += 1
mutex1.release()
print("----in test2 g_num=%d----" % g_num) mutex1 = threading.Lock()
def main(): t1 = threading.Thread(target=test1, args=(1000000,))
t2 = threading.Thread(target=test2, args=(1000000,)) t1.start()
t2.start() time.sleep(1) print("----in main gnum=%d----" % g_num) if __name__ == '__main__':
main()

多线程版UDP聊天器

import  socket
import threading # 接收数据
def recv_msg(udp_socket):
while True:
recv_data,data_from = udp_socket.recvfrom(1024)
print("来自%s: [%s] " % (data_from, recv_data.decode('gbk'))) # 接收数据
def send_msg(udp_socket):
while True:
send_data = input("输入要发送的数据:")
udp_socket.sendto(send_data.encode('gbk'),("192.168.2.193", 8080)) def main(): udp_socket = socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
# 2. 绑定本地信息
udp_socket.bind(("", 7890))
# 对方的连接信息,用的固定值,没有用变量传递 # 创建两个线程
t_recv = threading.Thread( target=recv_msg, args=(udp_socket,))
t_send = threading.Thread( target=send_msg, args=(udp_socket,)) t_recv.start()
t_send.start() if __name__ == '__main__':
main()

【python】多任务(1. 线程)的更多相关文章

  1. Python多任务之线程

    多任务介绍 我们先来看一下没有多任务的程序 import time def sing(): for i in range(5): print("我喜欢唱") time.sleep( ...

  2. Python 多任务(线程) day2 (2)

    同步 1.概念 :同步就是协同步调,按预定的先后次序运行 互斥锁 当多个线程几乎同时修改某一共享数据的时候,需要运行同步控制,最简单的同步机制是引入互斥锁.某个线程要更改共享数据时,先将其锁定,此时资 ...

  3. python多任务的实现:线程,进程,协程

    什么叫“多任务”呢?简单地说,就是操作系统可以同时运行多个任务.打个比方,你一边在用浏览器上网,一边在听MP3,一边在用Word赶作业,这就是多任务,至少同时有3个任务正在运行.还有很多任务悄悄地在后 ...

  4. python 进程、线程与协程的区别

    进程.线程与协程区别总结 - 1.进程是计算器最小资源分配单位 - 2.线程是CPU调度的最小单位 - 3.进程切换需要的资源很最大,效率很低 - 4.线程切换需要的资源一般,效率一般(当然了在不考虑 ...

  5. python学习笔记——线程threading (一)

    1 线程threading 1.1 基本概述 也被称为轻量级的进程. 线程是计算机多任务编程的一种方式,可以使用计算机的多核资源. 线程死应用程序中工作的最小单元 1.2 线程特点 (1)进程的创建开 ...

  6. python多线程与线程

    进程与线程的概念 进程 考虑一个场景:浏览器,网易云音乐以及notepad++ 三个软件只能顺序执行是怎样一种场景呢?另外,假如有两个程序A和B,程序A在执行到一半的过程中,需要读取大量的数据输入(I ...

  7. Python 基础之 线程与进程

    Python 基础之 线程与进程 在前面已经接触过了,socket编程的基础知识,也通过socketserver 模块实现了并发,也就是多个客户端可以给服务器端发送消息,那接下来还有个问题,如何用多线 ...

  8. python day 20: 线程池与协程,多进程TCP服务器

    目录 python day 20: 线程池与协程 2. 线程 3. 进程 4. 协程:gevent模块,又叫微线程 5. 扩展 6. 自定义线程池 7. 实现多进程TCP服务器 8. 实现多线程TCP ...

  9. Python进程、线程、协程

    进程和线程的解释 进程(process)和线程(thread)是操作系统的基本概念,计算机的核心是CPU,它承担了所有的计算任务: 单个CPU一次只能运行一个任务,代表单个CPU总是运行一个进程,其他 ...

  10. python进程、线程、协程(转载)

    python 线程与进程简介 进程与线程的历史 我们都知道计算机是由硬件和软件组成的.硬件中的CPU是计算机的核心,它承担计算机的所有任务. 操作系统是运行在硬件之上的软件,是计算机的管理者,它负责资 ...

随机推荐

  1. LeetCode 489. Robot Room Cleaner

    原题链接在这里:https://leetcode.com/problems/robot-room-cleaner/ 题目: Given a robot cleaner in a room modele ...

  2. 基于react开发package.json的配置

    项目依赖 react网页开发的3件套: react, react-dom, react-router-dom, redux, react-reduxreact的UI组件库: antd(pc端), an ...

  3. 安装服务器pve虚拟系统(可以通过web管理物理机集群资源与虚拟机)

    做此系统前,可以先进入bios,设置一下ipmi的网络地址.可以远程管理服务器 输入服务器的ipmi里面配置的ip 默认账号与密码admin 点击launch 会自动下载认证文件 下载好java软件环 ...

  4. PATA1012The Best Rank(25分)

    To evaluate the performance of our first year CS majored students, we consider their grades of three ...

  5. 1473. [Ioi2000]Post加强版 n log^2 n做法

    1473. [Ioi2000]Post加强版 n log^2 n做法 题面 有n个城市从负方向向正方向按照1至n标号,\(d[i]\)表示城市i离原点的距离并且\(d[1] = 0\),对于\(i \ ...

  6. Java高级开发_性能优化的细节

    一.核心部分总结: 尽量在合适的场合使用单例[减负提高效率] 尽量避免随意使用静态变量[GC] 尽量重用对象,避免过多过常地创建Java对象[最大限度地重用对象] 尽量使用final修饰符[内联(in ...

  7. mysql统计当前月和近30天每天的数据

    1,当前月 SELECT DATE_FORMAT(check_time,'%Y-%m-%d') as time, COUNT(*) FROM dw_rule WHERE check_state = 3 ...

  8. 非mvn项目转为mvn项目并构建mvn私服

    非mvn项目转为mvn项目并构建mvn私服 一.背景 公司里的系统是老系统,没有使用mvn,但是现在准备使用持续集成(CI),就要用到mvn,所以现在需要将老项目转为mvn项目,并且非mvn项目也是不 ...

  9. 用idea如何把一个写好的项目传到GitHub上

    原文地址:https://blog.csdn.net/u010775025/article/details/79219491 一.登录到自己的GitHub上,创建一个新的仓库如下图springboot ...

  10. 【linux】查看jar里面的配置文件

    1.vim 文件.jar 2.光标到配置文件,然后回车 3.退出命令:q 也可以进行编辑,按i进入编辑,按:wq保存退出