我剛剛從客戶的設備崩潰日誌,它的崩潰在這裏:我應該避免在全局隊列中創建JSContext嗎?
dispatch_async(dispatch_get_global_queue(0, 0), ^{
JSContext *javaScriptContext = [[JSContext alloc] init];
這裏的崩潰日誌:
Thread 11 Crashed:
0 JavaScriptCore 0x31009cd6 WTFCrash + 54
1 JavaScriptCore 0x30e0edf6 WTF::OSAllocator::reserveAndCommit(unsigned long, WTF::OSAllocator::Usage, bool, bool, bool) + 166
2 JavaScriptCore 0x30e0ed2a WTF::OSAllocator::reserveUncommitted(unsigned long, WTF::OSAllocator::Usage, bool, bool, bool) + 14
3 JavaScriptCore 0x30e14736 JSC::JSStack::JSStack(JSC::VM&, unsigned long) + 74
4 JavaScriptCore 0x30e146d2 JSC::Interpreter::Interpreter(JSC::VM&) + 22
5 JavaScriptCore 0x30e10fb8 JSC::VM::VM(JSC::VM::VMType, JSC::HeapType) + 2516
6 JavaScriptCore 0x30fbf48e JSC::VM::createContextGroup(JSC::HeapType) + 22
7 JavaScriptCore 0x30fbdc86 JSContextGroupCreate + 14
8 JavaScriptCore 0x30fd209e -[JSVirtualMachine init] + 6
9 JavaScriptCore 0x30fbd122 -[JSContext init] + 46
10 <redacted>
11 libdispatch.dylib 0x3a776d78 _dispatch_call_block_and_release + 8
12 libdispatch.dylib 0x3a77dda0 _dispatch_root_queue_drain + 216
13 libdispatch.dylib 0x3a77df88 _dispatch_worker_thread2 + 52
14 libsystem_pthread.dylib 0x3a8b8dbc _pthread_wqthread + 296
15 libsystem_pthread.dylib 0x3a8b8c80 start_wqthread + 4
WTFCrash,確實如此。
在這一點上,其他幾個線程都在忙於JavaScript相關記憶的東西:
Thread 10:
0 libsystem_kernel.dylib 0x3a83f970 _kernelrpc_mach_vm_deallocate_trap + 20
1 libsystem_kernel.dylib 0x3a83fc5a mach_vm_deallocate + 26
2 libsystem_kernel.dylib 0x3a83fc36 vm_deallocate + 14
3 JavaScriptCore 0x30e18f20 JSC::BlockAllocator::releaseFreeRegions() + 64
4 JavaScriptCore 0x30f89784 JSC::CopiedSpace::~CopiedSpace() + 20
5 JavaScriptCore 0x30faea28 JSC::Heap::~Heap() + 336
6 JavaScriptCore 0x30fbf434 JSC::VM::~VM() + 2600
7 JavaScriptCore 0x30e0bb82 JSC::JSLockHolder::~JSLockHolder() + 90
8 JavaScriptCore 0x30fbdcf8 JSContextGroupRelease + 76
9 JavaScriptCore 0x30fd21be -[JSVirtualMachine dealloc] + 22
10 libobjc.A.dylib 0x3a29eb06 objc_object::sidetable_release(bool) + 170
11 libobjc.A.dylib 0x3a290002 (anonymous namespace)::AutoreleasePoolPage::pop(void*) + 354
12 libdispatch.dylib 0x3a77de08 _dispatch_root_queue_drain + 320
13 libdispatch.dylib 0x3a77df88 _dispatch_worker_thread2 + 52
14 libsystem_pthread.dylib 0x3a8b8dbc _pthread_wqthread + 296
15 libsystem_pthread.dylib 0x3a8b8c80 start_wqthread + 4
Thread 15 name: JavaScriptCore::BlockFree
Thread 15:
0 libsystem_kernel.dylib 0x3a851f38 __psynch_cvwait + 24
1 libsystem_pthread.dylib 0x3a8ba224 _pthread_cond_wait + 536
2 libsystem_pthread.dylib 0x3a8bb040 pthread_cond_timedwait + 40
3 JavaScriptCore 0x30e12eb8 WTF::ThreadCondition::timedWait(WTF::Mutex&, double) + 104
4 JavaScriptCore 0x30e12ce4 JSC::BlockAllocator::blockFreeingThreadMain() + 88
5 JavaScriptCore 0x30e103a8 WTF::wtfThreadEntryPoint(void*) + 12
6 libsystem_pthread.dylib 0x3a8bac1a _pthread_body + 138
7 libsystem_pthread.dylib 0x3a8bab8a _pthread_start + 98
8 libsystem_pthread.dylib 0x3a8b8c8c thread_start + 4
Thread 16 name: JavaScriptCore::Marking
Thread 16:
0 libsystem_kernel.dylib 0x3a851f38 __psynch_cvwait + 24
1 libsystem_pthread.dylib 0x3a8ba224 _pthread_cond_wait + 536
2 libsystem_pthread.dylib 0x3a8bb000 pthread_cond_wait + 36
3 JavaScriptCore 0x30fae23e JSC::GCThread::waitForNextPhase() + 74
4 JavaScriptCore 0x30fae298 JSC::GCThread::gcThreadMain() + 48
5 JavaScriptCore 0x30e103a8 WTF::wtfThreadEntryPoint(void*) + 12
6 libsystem_pthread.dylib 0x3a8bac1a _pthread_body + 138
7 libsystem_pthread.dylib 0x3a8bab8a _pthread_start + 98
8 libsystem_pthread.dylib 0x3a8b8c8c thread_start + 4
Thread 17 name: JavaScriptCore::BlockFree
Thread 17:
0 libsystem_kernel.dylib 0x3a851f38 __psynch_cvwait + 24
1 libsystem_pthread.dylib 0x3a8ba224 _pthread_cond_wait + 536
2 libsystem_pthread.dylib 0x3a8bb040 pthread_cond_timedwait + 40
3 JavaScriptCore 0x30e12eb8 WTF::ThreadCondition::timedWait(WTF::Mutex&, double) + 104
4 JavaScriptCore 0x30e12ce4 JSC::BlockAllocator::blockFreeingThreadMain() + 88
5 JavaScriptCore 0x30e103a8 WTF::wtfThreadEntryPoint(void*) + 12
6 libsystem_pthread.dylib 0x3a8bac1a _pthread_body + 138
7 libsystem_pthread.dylib 0x3a8bab8a _pthread_start + 98
8 libsystem_pthread.dylib 0x3a8b8c8c thread_start + 4
所以...什麼是對一個全球性的隊列生成一個JSContext
問題?我應該怎樣做才能避免這個問題?
我實際上建議你應該避免創建如此多的獨特的JSContexts,如果你可以幫助它的話。相反,您應該嘗試利用單個JSContext(如果可能!),而不是每次創建全新的JSContext。是否可以利用單個JSContext進行隊列執行,而不是使用每個隊列項目創建新的JSContext? –
但是,這也只是一個天真的聲明,沒有真正知道爲什麼你需要爲每個隊列項目創建一個新的JSContext的原因的根源。如果您想更多地瞭解重複使用現有的JSContext來處理多種事情,我可以嘗試提供幫助! –