PDFDocument removePageAtIndex:更新到Mac OS X 10.11后不起作用

莫尼什·库玛(Monish kumar)

在此处输入图片说明在此处输入图片说明

我在PDFViewer的可可应用程序中使用了PDFKit Framework。当我尝试从PDFDocument删除页面之一时,该应用程序冻结在代码行处

[[self pdfDocument]  removePageAtIndex:0]; // can see this Problem only in Mac OS X 10.11

当我在Mac OS X 10.10中运行该应用程序时,这将完美工作

我阅读了所有相关的Apple文档,但还没有任何解决方案。

这是回溯:

* thread #1: tid = 0x85e1, 0x00007fff92571f5e libsystem_kernel.dylib`__psynch_cvwait + 10, queue = 'com.apple.main-thread', stop reason = signal SIGTERM
    frame #0: 0x00007fff92571f5e libsystem_kernel.dylib`__psynch_cvwait + 10
    frame #1: 0x00000001006c05f7 libsystem_pthread.dylib`_pthread_cond_wait + 767
    frame #2: 0x00007fff904c6e32 Foundation`-[__NSOperationInternal _waitUntilFinished:] + 131
    frame #3: 0x00007fff904921fa Foundation`-[NSOperationQueue waitUntilAllOperationsAreFinished] + 254
  * frame #4: 0x000000010017efe1 Neat`-[NRMPDFCoordinator waitUntilAllOperationsAreFinished](self=0x0000608000ad3be0, _cmd=0x00007fff8877e285) + 145 at NRMPDFCoordinator.m:1362
    frame #5: 0x00000001000109cf Neat`-[NRMItemEditorDocument saveDocumentWithDelegate:didSaveSelector:contextInfo:](self=0x000060000094a190, _cmd=0x00007fff88777581, delegate=0x0000000000000000, didSaveSelector=0x0000000000000000, contextInfo=0x0000000000000000) + 1151 at NRMItemEditorDocument.m:325
    frame #6: 0x000000010001018a Neat`-[NRMItemEditorDocument saveDocument:](self=0x000060000094a190, _cmd=0x00007fff8874cbb4, sender=0x00006080003a8b20) + 58 at NRMItemEditorDocument.m:234
    frame #7: 0x0000000100013bef Neat`-[NRMItemEditorWindowController saveAndClose:](self=0x00006080003a8b20, _cmd=0x00000001002cf2d2, sender=0x000060000094a5b0) + 95 at NRMItemEditorWindowController.m:244
    frame #8: 0x00007fff87068082 libsystem_trace.dylib`_os_activity_initiate + 75
    frame #9: 0x00007fff87fc79b5 AppKit`-[NSApplication sendAction:to:from:] + 460
    frame #10: 0x00007fff87fd9bb2 AppKit`-[NSControl sendAction:to:] + 86
    frame #11: 0x00007fff87fd9adc AppKit`__26-[NSCell _sendActionFrom:]_block_invoke + 131
    frame #12: 0x00007fff87068082 libsystem_trace.dylib`_os_activity_initiate + 75
    frame #13: 0x00007fff87fd9a39 AppKit`-[NSCell _sendActionFrom:] + 144
    frame #14: 0x00007fff87068082 libsystem_trace.dylib`_os_activity_initiate + 75
    frame #15: 0x00007fff87fd805e AppKit`-[NSCell trackMouse:inRect:ofView:untilMouseUp:] + 2693
    frame #16: 0x00007fff88020d1c AppKit`-[NSButtonCell trackMouse:inRect:ofView:untilMouseUp:] + 744
    frame #17: 0x00007fff87fd6788 AppKit`-[NSControl mouseDown:] + 669
    frame #18: 0x00007fff88524575 AppKit`-[NSWindow _handleMouseDownEvent:isDelayedEvent:] + 6322
    frame #19: 0x00007fff88525559 AppKit`-[NSWindow _reallySendEvent:isDelayedEvent:] + 212
    frame #20: 0x00007fff87f6ad31 AppKit`-[NSWindow sendEvent:] + 517
    frame #21: 0x00007fff87eeaccb AppKit`-[NSApplication sendEvent:] + 2540
    frame #22: 0x0000000100225f35 Neat`-[NRMApplication sendEvent:](self=0x00006000001205a0, _cmd=0x00007fff88749e04, event=0x0000608000725640) + 1141 at NRMApplication.m:95
    frame #23: 0x00007fff87d51f3e AppKit`-[NSApplication run] + 796
    frame #24: 0x00007fff87d1b162 AppKit`NSApplicationMain + 1176
    frame #25: 0x0000000100012d67 Neat`main(argc=3, argv=0x00007fff5fbff718) + 119 at main.m:21
    frame #26: 0x0000000100001e74 Neat`start + 52

这是我使用PDFDocument的removePageAtIndex方法的方法

-(NSError *)removePageOpImpl:(NRMPDFOperation *)op
{
    NSLog(@"\n Inside removePageOpImpl Method ...");
    NSError* error = [self loadDocument];
    if( !error )
    {
        NSUInteger index = [self pageIndexForId:[op pageId]];
        NSLog(@"Page count: %ld", [self pageCount]);
        if( index < [self pageCount] )
        {
            NSLog(@"PDF Document:-- %@", [self pdfDocument]);
            NSLog(@"Index is: %ld", index);
            @try {

                [(PDFDocument *)[self pdfDocument]  removePageAtIndex:index];//At this line the app getting freezed and control is ended.

                NSLog(@"Page count after delete: %ld", [self pageCount]);


            }
            @catch (NSException *exception) {
                NSLog(@"Exception: %@", exception);
            }
            @finally {
                NSLog(@"Finally called");
                [[self mutablePageIdList] removeObjectAtIndex:index];
                [self updatePageLabelsFromIndex:index];
                [self updateChangeCount:NSChangeDone];
                self.contentsChanged = YES;
            }
        }
        else
        {
            // TODO: error
        }
    }
    return error;
}

谁能建议我可能是问题所在...还附上了阻止用户界面的队列的屏幕截图

我尝试将主队列上的dispatch_async应用于如下所示的PDFDocument页面删除操作

- (NSError *)removePageOpImpl:(NRMPDFOperation *)op
{
    NSError* error = [self loadDocument];
    if( !error )
    {
        NSUInteger index = [self pageIndexForId:[op pageId]];
        if( index < [self pageCount] )
        {
                dispatch_async(dispatch_get_main_queue(), ^{
                        [[self pdfDocument] removePageAtIndex:index];
                        [[self mutablePageIdList] removeObjectAtIndex:index];
                        [self updatePageLabelsFromIndex:index];
                        [self updateChangeCount:NSChangeDone];
                        self.contentsChanged = YES;

                        });
        }
        else
        {
            // TODO: error
        }
    }
    return error;
}

现在应用程序没有挂起,但是我遇到了另一个问题。我还有其他操作应该在removePageOpImpl操作之后同步运行。但它们在removePageOpImpl完成之前执行,这正在改变我的应用程序的行为。您能建议我在removePageOpImpl之后如何同步执行其他操作吗?我阅读了有关完成处理程序的信息,但是在这种情况下,我对如何使用它感到困惑。

请建议

乔迪·哈金斯(Jody Hagins)

您在这里创建了一个不错的小僵局。

您的主线程正在等待操作完成,但是该操作(由此跟踪指示)...

在此处输入图片说明

如您所见,它正在后台线程上运行,并且正在等待信号量,该信号量很可能只会从主线程发出信号。dispatch_sync与主线程类似由于它发生在PDFDocument实现内部,因此我想它正在尝试确保它在返回给用户(读取器/写入器锁)之前在主线程上运行某些操作。

因此,您的主线程正在等待操作完成,而该操作正在等待主线程完成其尝试执行的操作。经典僵局。

发生这种情况是因为主线程启动了保存操作,然后等待所有操作完成再进行操作(但是其他一些工作也需要在主线程上运行)。

您需要将保存另存为异步操作,因此在等待操作完成时,它不会在主线程上运行。然后,保存完成后,如果必须更新UI,它可以通过在主线程上运行的完成块或委托报告其成功/失败。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

升级Mac OS X El Capitan后Git不起作用

mvn命令在Mac OS X Yosemite上不起作用

路径在Mac OS X 10.10.3上不起作用

Mac OS X:在命令处不起作用

mac os x 10.9 lua更新到最新的5.2.2

将OS X更新到El Capitan后的Mcrypt问题

更新到gradle 6.x后,Gradle代码损坏了。getVariantData()。getVariantConfiguration()不起作用

Mac OS X更新后损坏的python

Windows 10 Fall Creators更新后SourceTree不起作用

OS X`rlwrap coqtop`不起作用

更新后,Flutter 命令在 Mac OS 的终端中不起作用

更新到Windows 10 1903后,指纹传感器不起作用。(Dell G3 3579)

C ++ + SDL + OpenGL 3.3在Mac OS X上不起作用?

ftruncate在Mac OS X中的POSIX共享内存上不起作用

phpinfo()在Mac OS-X Capitan apache2服务器上不起作用

所有命令在Mac OS X Lion上均不起作用

scp命令不起作用:远程主机关闭了连接(Mac OS X)

NSExtensionContext openURL在Mac OS X Today小部件上不起作用

硬链接在Mac OS X的GUI模式下不起作用

删除OS X上的钥匙串后git push不起作用

升级到OS X Yosemite后,pip不起作用

更新到Mac OS 10.15 Catalina后未打开Xcode 11

对于Mac OS X 10.9.1,将pg gem从0.17.0更新到0.17.1时出错

如何在Mac OS X上将Git从系统默认更新到最新

Mac OS X更新后的GRUB 2问题

如何从 Mac 的终端访问 Jupyter Notebook [将 Mac OS 从 High Sierra 更新到 Catalina 后]

Karabiner不起作用(Mac OS Sierra)

如何在Windows 10上安装mac OS X ElCapitan

Xcode 11更新后,Multipeer连接不起作用