import threading
import time """
python的thread模块是比较底层的模块,python的threading模块是对thread做了一些包装的,可以更加方便的被使用
多线程程序的执行顺序是不确定的,当线程被阻塞(Blocked)时,线程挂起,阻塞结束后,线程进入就绪(Runnable)状态,等待调度。
而线程调度将自行选择一个线程执行。只能保证每个线程都运行完整个run函数,但是线程的启动顺序、run函数中每次循环的执行顺序都不能确定。
也就是说:
1.每个线程默认有一个名字,尽管上面的例子中没有指定线程对象的name,但是python会自动为线程指定一个名字。
2.当线程的run()方法结束时该线程完成。
3.无法控制线程调度程序,但可以通过别的方式来影响线程调度的方式。
""" G_num = 0 def test_thread_1():
print("test_thread_1 子线程被调用, 休眠2秒")
time.sleep(2)
print("test_thread_1 子线程执行结束") def test_mutex_1(mutex, num): # 声明使用全局变量
global G_num for i in range(num):
if mutex.acquire(True): # 上锁,True表示进行堵塞,也就是说如果上锁失败,就阻塞在这一步,直到上锁成功
G_num += 1
# 释放锁
mutex.release() def test_mutex_2(mutex, num):
# 声明使用全局变量
global G_num for i in range(num):
if mutex.acquire(True): # 上锁,True表示进行堵塞,也就是说如果上锁失败,就阻塞在这一步,直到上锁成功
G_num += 1
# 释放锁
mutex.release() class MyThread(threading.Thread): # 继承自threading.Thread类
"""
为了让每个线程的封装性更完美,所以使用threading模块时,往往会定义一个新的子类class,
只要继承threading.Thread就可以了,然后重写run方法
"""
# 重写run方法
def run(self):
# name属性,当前线程的名字
print("自己封装的线程类,当前线程名字:%s" % self.name) # python的threading.Thread类有一个run方法,用于定义线程的功能函数,
# 可以在自己的线程类中覆盖该方法。而创建自己的线程实例后,通过Thread类的start方法,
# 可以启动该线程,交给python虚拟机进行调度,当该线程获得执行的机会时,就会调用run方法执行线程。 def make_thread():
# 将函数引用使用target命名参数进行传递,创建子线程
thread = threading.Thread(target=test_thread_1) # 启动子线程
thread.start()   # 自定义的线程类
my_thread = MyThread()
my_thread.start() # 创建一个互斥锁
# 这个锁默认是未上锁的状态
mutex = threading.Lock()
t1 = threading.Thread(target=test_mutex_1, args=(mutex, 1000000, ))
t1.start()
t2 = threading.Thread(target=test_mutex_2, args=(mutex, 1000000, ))
t2.start() # 默认情况下,主线程会等待子线程
# t1 线程阻塞, 当t1完成执行后再进行下一步操作
# t1.join() # t1 线程守护主线程
# t1.daemon = True # 获取当前进程下的所有线程数量(包含主线程)
# length = len(threading.enumerate())
# print("线程数量:%d" % length)
# print("主线程执行到最后一行") while True:
length = len(threading.enumerate())
if length == 1:
return G_num
else:
time.sleep(0.2) num = make_thread()
print(num)

输出:

test_thread_1 子线程被调用, 休眠2秒
自己封装的线程类,当前线程名字:Thread-2
test_thread_1 子线程执行结束
2000000

python 使用多线程进行并发编程/互斥锁的使用的更多相关文章

  1. 并发编程---互斥锁---互斥锁与join的区别

    互斥锁 互斥锁:就是把多个进程并发,修改成一块共享数据的操作变成串行,保证是一个一个来修改的. 缺点:效率低,加锁过程复杂 优点:增加了安全性 from multiprocessing import ...

  2. 已看1.熟练的使用Java语言进行面向对象程序设计,有良好的编程习惯,熟悉常用的Java API,包括集合框架、多线程(并发编程)、I/O(NIO)、Socket、JDBC、XML、反射等。[泛型]\

    1.熟练的使用Java语言进行面向对象程序设计,有良好的编程习惯,熟悉常用的Java API,包括集合框架.多线程(并发编程).I/O(NIO).Socket.JDBC.XML.反射等.[泛型]\1* ...

  3. Java 多线程高并发编程 笔记(一)

    本篇文章主要是总结Java多线程/高并发编程的知识点,由浅入深,仅作自己的学习笔记,部分侵删. 一 . 基础知识点 1. 进程于线程的概念 2.线程创建的两种方式 注:public void run( ...

  4. python 使用多进程实现并发编程/使用queue进行进程间数据交换

    import time import os import multiprocessing from multiprocessing import Queue, pool ""&qu ...

  5. 多线程高并发编程(3) -- ReentrantLock源码分析AQS

    背景: AbstractQueuedSynchronizer(AQS) public abstract class AbstractQueuedSynchronizer extends Abstrac ...

  6. Java并发编程:锁的释放

    Java并发编程:锁的释放 */--> code {color: #FF0000} pre.src {background-color: #002b36; color: #839496;} Ja ...

  7. Java 多线程:并发编程的三大特性

    Java 多线程:并发编程的三大特性 作者:Grey 原文地址: 博客园:Java 多线程:并发编程的三大特性 CSDN:Java 多线程:并发编程的三大特性 可见性 所谓线程数据的可见性,指的就是内 ...

  8. python多线程,event,互斥锁,死锁,递归锁,信号量

    Python多线程/event 多线程-threading python的thread模块是⽐较底层的模块, python的threading模块是对thread做了⼀些包装的, 可以更加⽅便的被使⽤ ...

  9. python之旅:并发编程之多线程

    一 threading模块介绍 multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性,因而不再详细介绍 官网链接:https://docs.python ...

随机推荐

  1. python-反射案例讲解

    login.py#!/usr/bin/dev python# coding:utf-8 def index(): print u'欢迎访问xx网站首页' def login(): print u'登录 ...

  2. WPF程序 双击exe自动申请“以管理员方式运行”权限

    实现方式: 在 xxx.exe 目录下包含其对应的清单文件(xxx.exe.manifest, 由 VS 编译时自动生成): 用记事本打开 manifest 文件,将文件中的项:<request ...

  3. GDI+_入门教程【一】

    GDI For VisualBasic6.0 [一]文件下载:GDI+ For VB6[一] 简单绘图实例演示百度网盘 1 '以下为作者[vIsiaswx]的教程 '(该教程发布的原地址已无法访问,此 ...

  4. toString() 数组转字符串

    var monthNames = ['Jan', 'Feb', 'Mar', 'Apr']; var myVar = monthNames.toString(); // assigns "J ...

  5. [Ting's笔记Day3]解决Git常见错误non-fast-forward问题

    写文章最难的部分,是找题材! 所以最近每次遇到bug或错误都挺兴奋开心(zflwx)的,因为又可以写笔记了 也可以记录新手学习之路上遇到的常见问题,提供其他新手参考. 最近学Udemy平台Ruby学习 ...

  6. CSS 图像居中对齐

    CSS  图像居中对齐 我们在<CSS 内外边距>学过内容居中,它的原理是将外边左右设置为auto.图像居中也是这个原理. 示例 <!DOCTYPE html> <htm ...

  7. scrapy使用MongoDB简单示例

    1.下载安装MongoDBhttps://www.mongodb.com/download-center#community找到合适的版本下载,安装.安装好之后,找到安装目录下D:\Program F ...

  8. Python设计模式 - UML - 部署图(Deployment Diagram)

    简介 部署图也称配置图,用来显示系统中硬件和软件的物理架构.从中可以了解到软件和硬件组件之间的物理拓扑.连接关系以及处理节点的分布情况. 部署图建模步骤 - 找出需要进行部署的各类节点,如网络硬件设备 ...

  9. redis、mysql、mongdb的比较

    特点: 1-1 MySQL:1. 使用c和c++编写,并使用了多种编译器进行测试,保证源代码的可移植性2. 支持多种操作系统3. 为多种编程语言提供可API4. 支持多线程,充分利用CPU资源优化的S ...

  10. ASP 错误捕捉,处理

    Asp利用 On Error Resume Next捕捉异常,根据Err.Number判断是否有错误 注:On Error Goto 0取消捕捉异常 模板文件页面 <% Response.Buf ...