Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/cocoa/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Macos PDFDocument removePageAtIndex:更新到Mac OS X 10.11时不工作_Macos_Cocoa - Fatal编程技术网

Macos PDFDocument removePageAtIndex:更新到Mac OS X 10.11时不工作

Macos PDFDocument removePageAtIndex:更新到Mac OS X 10.11时不工作,macos,cocoa,Macos,Cocoa,我正在将PDFKit框架用于我的cocoa应用程序(用于PDFViewer)。当我试图从PDF文档中删除其中一个页面时,该应用程序在代码行处冻结 [[self pdfDocument] removePageAtIndex:0]; // can see this Problem only in Mac OS X 10.11 当我在Mac OS X 10.10中运行应用程序时,这一点非常有效 我阅读了所有相关的苹果文档,但还没有找到任何解决方案 以下是回溯: * thread #1: tid =

我正在将PDFKit框架用于我的cocoa应用程序(用于PDFViewer)。当我试图从PDF文档中删除其中一个页面时,该应用程序在代码行处冻结

[[self pdfDocument]  removePageAtIndex:0]; // can see this Problem only in Mac OS X 10.11
当我在Mac OS X 10.10中运行应用程序时,这一点非常有效

我阅读了所有相关的苹果文档,但还没有找到任何解决方案

以下是回溯:

* 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;
}
-(NSError*)removePageOpImpl:(nrmpdOperation*)操作
{
NSLog(@“\n在removePageOpImpl方法中…”);
N错误*错误=[self-loadDocument];
如果(!错误)
{
NSUInteger index=[self-pageIndexForId:[op-pageId]];
NSLog(@“页面计数:%ld”,[self pageCount]);
如果(索引<[self pageCount])
{
NSLog(@“PDF文档:-%@,[self-pdfDocument]);
NSLog(@“索引为:%ld”,索引);
@试一试{
[(PDFDocument*)[self PDFDocument]removePageAtIndex:index];//在此行,应用程序被冻结,控制结束。
NSLog(@“删除后的页面计数:%ld”,[self pageCount]);
}
@捕获(NSException*异常){
NSLog(@“异常:%@”,异常);
}
@最后{
NSLog(@“最终调用”);
[[self-mutablePageIdList]removeObjectAtIndex:index];
[self-updatePageLabelsFromIndex:index];
[自我更新更改计数:NSChangeDone];
self.contentsChanged=是;
}
}
其他的
{
//TODO:错误
}
}
返回误差;
}
谁能告诉我可能有什么问题。。。还附上了阻塞UI的队列的屏幕截图

我尝试将主队列上的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;
}
-(NSError*)removePageOpImpl:(nrmpdOperation*)操作
{
N错误*错误=[self-loadDocument];
如果(!错误)
{
NSUInteger index=[self-pageIndexForId:[op-pageId]];
如果(索引<[self pageCount])
{
dispatch\u async(dispatch\u get\u main\u queue()^{
[[self pdfDocument]移除页面索引:索引];
[[self-mutablePageIdList]removeObjectAtIndex:index];
[self-updatePageLabelsFromIndex:index];
[自我更新更改计数:NSChangeDone];
self.contentsChanged=是;
});
}
其他的
{
//TODO:错误
}
}
返回误差;
}
现在应用程序没有挂起,但我遇到了另一个问题。在removePageOpImpl操作之后,我还有其他应该同步运行的操作。但它们是在removePageOpImpl完成之前执行的,这改变了我的应用程序的行为。您能建议我如何在removePageOpImpl之后同步执行其他操作吗。我读过有关完成处理程序的内容,但在这个场景中,我对如何使用它感到困惑


请建议

您在这里造成了一个很好的小僵局

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

正在后台线程上运行,正如您所看到的,它正在等待一个信号量,这个信号量很可能只会从主线程发出信号。这具有类似于
dispatch\u sync
到主线程的标记。由于它发生在
PDFDocument
实现中,我认为它试图确保在返回到用户(读写器锁)之前在主线程上运行某些东西

因此,主线程正在等待一个操作完成,而该操作正在等待主线程完成它试图完成的操作。经典死锁

发生这种情况的原因是主线程启动保存,然后等待一切完成,然后再继续(但其他一些工作也需要在主线程上运行)


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

您能发布堆栈回溯吗?@Aderstedt:我试图打印回溯,但它没有打印任何内容。你是从Xcode中运行应用程序吗?如果是,你应该在那里看到回溯。是的,我在Xcode中运行应用程序。但是当应用程序冻结时,项目导航面板中的回溯变得清晰,控制台不允许我运行bt命令;(@Aderstedt:我用backtrace编辑了这个问题。你的回答真的很有帮助,谢谢。你能澄清我的观点吗。如果我处理队列的设计不正确,那么在没有UI挂起的所有以前的OS X版本中它是如何工作的。这是我脑子里一直存在的唯一疑问。谁知道呢。也许他们改变了PDFDocument的运作方式有时,我们会做一些不正确的事情,但它不会中断…这就是为什么我们应该总是尝试做“正确的事情”我用我面临的另一个问题更新了我的问题,你能就此向我提出建议吗。@MonishKumar-添加问题不是正确的方法,因此你应该创建一个新问题,与你现在遇到的问题完全相同。请确保包括你的代码、你期望发生的事情以及发生的事情。谢谢你的建议。我将创建一个新的问题不同的问题,所以会标记你。