6

我的应用程序有一个自定义音频库,它本身使用 BASS 库。

我在整个程序中创建和销毁 BASS 流对象。

当我的程序随机退出时(我还没有弄清楚模式),我在控制台上收到以下通知:

Exception TypeError: "'NoneType' object is not callable" in <bound method stream.__del__ of <audio.audio_player.stream object at 0xaeda2f0>> ignored

我的音频库(audio/audio_player.py [class Stream])包含一个创建 BASS 流对象并允许代码对其进行操作的类。当类被销毁时(在del例程中),它调用 BASS_StreamFree 来清除 BASS 可能分配的任何资源。

(audio_player.py)

from pybass import *
from ctypes import pointer, c_float, c_long, c_ulong, c_buffer
import os.path, time, threading

# initialize the BASS engine
BASS_Init(-1, 44100, 0, 0, None)

class stream(object):
    """Represents a single audio stream"""
    def __init__(self, file):
        # check for file existence
        if (os.path.isfile(file) == False):
            raise ValueError("File %s not found." % file)
        # initialize a bass channel
        self.cAddress = BASS_StreamCreateFile(False, file, 0, 0, 0)
    def __del__(self):
        BASS_StreamFree(self.cAddress)
    def play(self):
        BASS_ChannelPlay(self.cAddress, True)
        while (self.playing == False):
            pass
    ..more code..

基于此消息,我的第一个倾向是在我的代码中的某个地方,我的流类的一个实例被孤立(不再分配给变量)并且 Python 仍在尝试在应用程序关闭时调用它的del函数,但是到了时间它尝试对象已经消失。

这个应用程序确实使用 wxWidgets,因此涉及一些线程。没有给我一个实际的变量名这一事实让我相信我在上一段中所说的话。

我不确定究竟什么代码与调试相关。该消息似乎无害,但我不喜欢最终生产代码中“忽略”异常的想法。

有没有人有任何调试这个的提示?

4

1 回答 1

11

异常被忽略的消息是因为__del__方法中引发的所有异常都被忽略以保持数据模型的健全。这是文档的相关部分:

警告:由于__del__()调用方法的环境不稳定,在执行过程中发生的异常会被忽略,并且会向 sys.stderr 打印警告。此外,当__del__()响应于模块被删除而被调用时(例如,当程序执行完成时),该__del__()方法引用的其他全局变量可能已经被删除或正在被拆除(例如,导入机器关闭)。为此原因,__del__()方法应该做维护外部不变量所需的绝对最小值。从 1.5 版开始,Python 保证名称以下划线开头的全局变量会在其他全局变量被删除之前从其模块中删除;__del__()如果不存在对此类全局变量的其他引用,这可能有助于确保在调用方法时导入的模块仍然可用。

至于调试它,您可以首先在您的方法中的代码周围放置一个try/块,并在它发生时打印出有关程序状态的更多信息。或者你可以考虑在方法中做更少的事情,或者完全摆脱它!except__del____del__

于 2013-05-18T05:22:22.960 回答