1

我有一个允许事件委托模式的搜索类。其他类可以注册一个函数,以便在搜索更新时调用。

出现问题时,回溯不会显示接收器功能。例如:

我的搜索类运行这个......

# ----------- Search.py -----------
# class Search ...snip...
    def connect(self, fn):
        self.__updateDelegates.append(fn)

    def onTextChanged(self):
        # ...snip...
        # Execute all event delegates
        for fn in self.__updateDelegates:
            fn(search_pattern)

...如果委托函数签名是错误的...

# ----------- Foo.py -----------
from search import Search
# class Foo ...snip...
    def __init__(self):
        search = Search()
        search.connect(self.onSearchUpdate)

    def onSearchUpdate(self): # <- Wrong on purpose. Should have another argument
        # Do something.

……我看到了……

# Traceback (most recent call last):
#   File "search.py", line 287, in onTextChanged
#     fn(search_pattern)
# TypeError: onSearchUpdate() takes exactly 1 argument (2 given)

请注意,异常消息中的委托函数名称是正确的,但回溯并没有那么远。

错误是因为委托签名应该有一个模式参数。问题是回溯没有显示此错误发生的位置。它应该更远地回到引用指向的函数对象。

知道如何解决这个问题吗?

注意:我更新了代码和解释。我不想用额外的代码来混淆这个问题,但我觉得我需要展示更多。这不显示是什么触发了该功能onTextChanged()。这实际上是 Qt 小部件实现的一部分,当有人输入 QLineEdit 时它会运行此功能。所以模式是,父小部件创建搜索小部件,然后连接它的函数以在文本更改时调用。我希望这有帮助。

4

1 回答 1

1

假设onSearchUpdate是类上的一个方法Foo

class Foo(object):
    def __init__(self,search_pattern):
        self.search_pattern=search_pattern
    def onSearchUpdate(self):
        pass #do something with search_pattern

现在在课堂Search上,你以某种方式填充__updateDelegates

pattern=['foo','bar','baz']

class Search(object):
    def __init__(self):
       self.__updateDelegates=[]
       for i in range(3):
           self.__updateDelegates(Foo(pattern[i]).onSearchUpdate)

现在,当您调用onSearchUpdatevia时__updateDelegates,您只需执行以下操作:

for func in self.__updateDelegates:
    func()

这可能不是您的代码的结构方式(用您的代码段很难分辨),但希望这能说明问题。

或者,也许onSearchUpdate应该有第二个论点?

def onSearchUpdate(self,pattern):
   pass # snip ...
于 2012-07-20T18:42:08.667 回答