博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
A Basic Example of Threads Synchronization in Python, python中的线程同步示例
阅读量:6423 次
发布时间:2019-06-23

本文共 3481 字,大约阅读时间需要 11 分钟。

http://zulko.github.io/blog/2013/09/19/a-basic-example-of-threads-synchronization-in-python/

 

 

We will see how to use threading Events to have functions in different Python threads start at the same time.

I recently coded a method to view movies in Python : it plays the video, and in the same time, in a parralel thread, it renders the audio. The difficult part is that the audio and video should be exactly synchronized. The pseudo-code looks like this:

1234
def view(movie): new_thread( play_audio( movie ) ) play_video( movie )

In this code, play_audio() and play_video() will start at approximately the same time and will run parallely, but these functions need some preparation before actually starting playing stuff. Their code looks like that:

123456 7 8 9 10
def play_audio(movie): audio = prepare_audio( movie ) audio.start_playing() def play_video(movie): video = prepare_video( movie ) video.start_playing()

To have a well-synchronized movie we need the internal functions audio.start_playing() and video.start_playing(), which are run in two separate threads, to start at exactly the same time. How do we do that ?

The solution seems to be using threading.Event objects. An Event is an object that can be accessed from all the threads and allows very basic communication between them : each thread can set or unset an Event, or check whether this event has already been been set (by another thread).

For our problem we will use two events video_ready and audio_ready which will enable our two threads to scream at each other “I am ready ! Are you ?”. Here is the Python fot that:

123456 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
import threadingdef play_audio(movie, audio_ready, video_ready): audio = prepare_audio( movie ) audio_ready.set() # Say "I'm ready" to play_video() video_ready.wait() # Wait for play_video() to say "I'm ready" audio.start_playing() def play_video(movie, audio_ready, video_ready): video = prepare_video( movie ) video_ready.set() # Say "I'm ready" to play_audio() audio_ready.wait() # Wait for play_audio() to say "I'm ready" video.start_playing()

and finally the code for view(movie):

123456 7 8 9 10 11 12
def view(movie): audio_ready = threading.Event() video_ready = threading.Event() # launch the parrallel audio thread audiothread = threading.Thread(target=play_audio, args = (movie, audio_ready, video_ready)) audiothread.start() play_video(movie, audio_ready, video_ready)

A few tips tips to go further:

  • Here I am using the module threading, and the two threads will be played in parrallel on the same processor. If you have a computer with several processors you can also use the multiprocessing module to have your threads played on two different processors (which can be MUCH faster). Nicely enough the two modules have the same syntax: simply replace threading by multiprocessing and Thread by Process in the example above and it should work.
  • In , I also use an Event to terminate play_video and play_audio at the same time: when the video playing is exited, play_video unsets that Event. In play_audio, this event is regularly checked, and when it is seen to be unset, play_audio exits too.
  • Instead of using wait to wait for an Event to be set, you can use a loop to you decide at which frequency you want to check the Event. Only do that if don’t mind a lag of a few milliseconds between your processes :
123
import timewhile not audio_ready.is_set(): time.sleep(0.002) # sleep 2 milliseconds

 

 

 

 

 

转载地址:http://dmrra.baihongyu.com/

你可能感兴趣的文章
TortoiseGit:记住用户名和密码
查看>>
数据库的检索语句
查看>>
cocos2d-x3.0 实现HTTP请求GET、POST
查看>>
Iptables DDOS/CC 自动屏蔽脚本
查看>>
WPF VLC客户端和SDK的简单应用
查看>>
mysql函数之三:find_in_set() 函数 返回str在字符串集strlist中的序号
查看>>
js或者cs代码拼接html
查看>>
应用系统如何分析和获取SQL语句的执行代码
查看>>
拿年终奖前跳槽,你才是赢家!
查看>>
Mouse Key Hook
查看>>
MySQL占用内存过大的问题解决
查看>>
[Android] 转移“植物大战僵尸2”存档的办法,无需root
查看>>
【Xamarin挖墙脚系列:Xamarin开发环境配置需求】
查看>>
hdu5086——Revenge of Segment Tree
查看>>
8个经过证实的方法:提高机器学习模型的准确率
查看>>
C#中的文件同步
查看>>
libevent的使用(socket)
查看>>
Hadoop 的常用组件一览
查看>>
MongoDB安装、CURD增改查删操作、应用场景
查看>>
poj 3020 Antenna Placement (最小路径覆盖)
查看>>