python - pyaudio stream.close()導(dǎo)致程序崩潰且不能捕獲到異常
問題描述
我想要頻繁地使用pyaudio來播放音頻,雖然他不是多線程模塊,但是只使用一個(gè)子線程播放,主線程控制播放的開關(guān)應(yīng)該是沒有問題的。但是當(dāng)我使用它播放時(shí)遇到了不能解決的麻煩。
import threadingimport waveimport pyaudioimport timepa=pyaudio.PyAudio()f=wave.open(’/home/dyan/catkin_ws/src/hlf_robot/scripts/hlf_voice/my.wav’,’rb’)raw_data=f.readframes(f.getnframes())f.close()samplewidth,channels,framerate,raw_data=2,1,16000,raw_datai=0stream1=’’def test(): while True:global i,pa,stream1try: print i stream1=pa.open(format=pa.get_format_from_width(samplewidth), channels=channels, rate=framerate, output=True) stream1.write(raw_data)i+=1 print iexcept IOError,e:print eexcept Exception,e:print ebreakt0=threading.Thread(target=test)t0.start()time.sleep(3)while True: if stream1.is_active():print 'is_active' else:print 'not active' if stream1.is_stopped():print 'is_stopped' else:print 'not stopped' print stream1._is_running print stream1._stream print ’123’ try:stream1.stop_stream()print ’456’stream1.close() except Exception,e:print ebreak print ’789’ time.sleep(3)
輸出是這樣的,然后崩了
0#子線程循環(huán)第一次is_active#not stopped #True #stream1._is_running<_portaudio.Stream object at 0x7efd71e00cb0> #stream1._stream123 #調(diào)用stop_stream()之前456 #調(diào)用stop_stream()之后,close()之前[Errno Unanticipated host error] -9999 #子線程捕獲到主線程調(diào)用stream1.stop_stream()時(shí)由stream1.write()拋出的異常IOError,忽略這個(gè)異常繼續(xù)執(zhí)行0#子線程stream1.write()拋出異常i+=1未執(zhí)行繼續(xù)循環(huán)在pa.open()之前的print
1、也就是說在調(diào)用stream1.stop_stream()后調(diào)用stream1.close()導(dǎo)致程序崩潰了,而且子線程和主線程都沒有捕獲到異常!!!!2、如果將stop_stream()后的close()注釋掉短時(shí)間內(nèi)沒有任何問題,但是持續(xù)運(yùn)行大約10分鐘左右雖然不會(huì)崩潰但是再也不能繼續(xù)播放。pa.open()一直拋出異常[Errno Illegal combination of I/O devices] -9993,當(dāng)我關(guān)閉程序重啟時(shí)pa.open()會(huì)拋出異常(’Invalid sample rate’, -9997),播放用不了了!!!
這個(gè)問題該如何解決?
暫時(shí)使用每次播放均重開一個(gè)pyaudio.Pyaudio()對(duì)象的方式解決,這大概額外使用了cpu時(shí)間10ms。持續(xù)跑了將近20個(gè)小時(shí)沒出問題。
...try: self.pa=pyaudio.PyAudio()self.stream=self.pa.open(format=self.pa.get_format_from_width(samplewidth), channels=channels, rate=framerate, output=True) self.stream.write(raw_data)except IOError,e: passfinally: self.stream.close() self.pa.terminate()...
問題解答
回答1:這裡給了一個(gè)可能解決方法(workaround),ghost commented on 30 Jul 2016
相關(guān)文章:
1. apache web server 怎么限制某一個(gè)網(wǎng)站對(duì)服務(wù)器資源的占用?2. docker網(wǎng)絡(luò)端口映射,沒有方便點(diǎn)的操作方法么?3. docker start -a dockername 老是卡住,什么情況?4. java中返回一個(gè)對(duì)象,和輸出對(duì)像的值,意義在哪兒5. css3 - 純css實(shí)現(xiàn)點(diǎn)擊特效6. mysql - 在不允許改動(dòng)數(shù)據(jù)表的情況下,如何優(yōu)化以varchar格式存儲(chǔ)的時(shí)間的比較?7. 安全性測試 - nodejs中如何防m(xù)ySQL注入8. docker - 各位電腦上有多少個(gè)容器啊?容器一多,自己都搞混了,咋辦呢?9. javascript - 關(guān)于apply()與call()的問題10. html5 - 請(qǐng)問現(xiàn)在主流的前端自動(dòng)化構(gòu)建工具是哪個(gè)?
