[NSSearchField object]:发送到实例的无法识别的选择器



我在一个简单的Mac应用中测试Swift。我在Storyboard中有一个NSToolbar,并在里面画一个NSSearchfield。nssearchfield连接到第一响应者的方法controlTextDidChange(第一响应者是我添加NSTextFieldDelegate的ViewController)。

方法:

@IBAction override func controlTextDidChange(obj: NSNotification!) {
    println("searching...")
    println(obj.object.stringValue)
}

每当搜索新字符时,该方法都会正确调用,并且应用程序不会崩溃,但是返回的内容如下:

searching...
2014-08-03 09:56:57.770 TestApp[1129:24219] -[NSSearchField object]: unrecognized selector sent to instance 0x6080001a07e0
2014-08-03 09:56:57.770 TestApp[1129:24219] -[NSSearchField object]: unrecognized selector sent to instance 0x6080001a07e0
2014-08-03 09:56:57.775 TestApp[1129:24219] (
0   CoreFoundation                      0x00007fff92e6af1c __exceptionPreprocess + 172
1   libobjc.A.dylib                     0x00007fff930ae74e objc_exception_throw + 43
2   CoreFoundation                      0x00007fff92e6de4d -[NSObject(NSObject) doesNotRecognizeSelector:] + 205
3   CoreFoundation                      0x00007fff92db63c4 ___forwarding___ + 1028
4   CoreFoundation                      0x00007fff92db5f38 _CF_forwarding_prep_0 + 120
5   TestApp                           0x000000010000c187 _TFC9TestApp14ViewController20controlTextDidChangefS0_FGSQCSo14NSNotification_T_ + 231
6   TestApp                           0x000000010000c582 _TToFC9TestApp14ViewController20controlTextDidChangefS0_FGSQCSo14NSNotification_T_ + 66
7   libsystem_trace.dylib               0x00007fff9117bc07 _os_activity_initiate + 75
8   AppKit                              0x00007fff8d52b168 -[NSApplication sendAction:to:from:] + 410
9   AppKit                              0x00007fff8d52af90 -[NSControl sendAction:to:] + 86
10  AppKit                              0x00007fff8d6faf91 __26-[NSCell _sendActionFrom:]_block_invoke + 131
11  libsystem_trace.dylib               0x00007fff9117bc07 _os_activity_initiate + 75
12  AppKit                              0x00007fff8d57329e -[NSCell _sendActionFrom:] + 144
13  AppKit                              0x00007fff8d92fe8f __64-[NSSearchFieldCell(NSSearchFieldCell_Local) _sendPartialString]_block_invoke + 63
14  libsystem_trace.dylib               0x00007fff9117bc07 _os_activity_initiate + 75
15  AppKit                              0x00007fff8d92fe47 -[NSSearchFieldCell(NSSearchFieldCell_Local) _sendPartialString] + 186
16  Foundation                          0x00007fff932ee3d3 __NSFireTimer + 95
17  CoreFoundation                      0x00007fff92dbf464 __CFRUNLOOP_IS_CALLING_OUT_TO_A_TIMER_CALLBACK_FUNCTION__ + 20
18  CoreFoundation                      0x00007fff92dbf0f3 __CFRunLoopDoTimer + 1059
19  CoreFoundation                      0x00007fff92e320fd __CFRunLoopDoTimers + 301
20  CoreFoundation                      0x00007fff92d7b4d2 __CFRunLoopRun + 2018
21  CoreFoundation                      0x00007fff92d7aaa8 CFRunLoopRunSpecific + 296
22  HIToolbox                           0x00007fff90adcaff RunCurrentEventLoopInMode + 235
23  HIToolbox                           0x00007fff90adc872 ReceiveNextEventCommon + 431
24  HIToolbox                           0x00007fff90adc6b3 _BlockUntilNextEventMatchingListInModeWithFilter + 71
25  AppKit                              0x00007fff8d35c2a5 _DPSNextEvent + 1000
26  AppKit                              0x00007fff8d35ba79 -[NSApplication nextEventMatchingMask:untilDate:inMode:dequeue:] + 139
27  AppKit                              0x00007fff8d34fad3 -[NSApplication run] + 594
28  AppKit                              0x00007fff8d33b2de NSApplicationMain + 1778
29  TestApp                           0x000000010000da72 top_level_code + 34
30  TestApp                           0x000000010000daaa main + 42
31  libdyld.dylib                       0x00007fff8cb765c9 start + 1
32  ???                                 0x0000000000000003 0x0 + 3
)

我无法找出"无法识别的选择器发送到实例"来自哪里。

controlTextDidChange方法期望NSSearchField!,而不是NSNotification!

代替

@IBAction override func controlTextDidChange(obj: NSNotification!) {
    println("searching...")
    println(obj.object.stringValue)
}

@IBAction override func controlTextDidChange(obj: NSSearchField!) {
    println("searching...")
    println(obj.stringValue)
}

通过定义自定义方法解决

@IBAction func controlTextDidChange_Custom(obj: NSSearchField!) {
    if (!obj.stringValue.isEmpty) {
        println("Searched: (obj.stringValue)")
    } else {
        println("EMPTY")
    }
}

相关内容

  • 没有找到相关文章

最新更新