Simulador do Xcode 8.2 travar ao salvar captura de tela

103

Após a atualização do XCode 8.2, toda vez que salvar a captura de tela do simulador sempre o fazia travar. Mesmo eu redefinindo o conteúdo e as configurações ainda falham.

Devo remover todos os simuladores e instalá-los novamente?

Atualização :

  • 8.2.1 tem o mesmo problema.
  • 8.3 apenas Sierra com suporte.

A seguir está o relatório de falha:

Process:               Simulator [48928]
Path:                  /Applications/Xcode.app/Contents/Developer/Applications/Simulator.app/Contents/MacOS/Simulator
Identifier:            com.apple.iphonesimulator
Version:               10.0 (726.7)
Build Info:            Indigo-726007000000000~5
Code Type:             X86-64 (Native)
Parent Process:        ??? [1]
Responsible:           Simulator [48928]
User ID:               501

PlugIn Path:             /Applications/Xcode.app/Contents/Frameworks/libswiftFoundation.dylib
PlugIn Identifier:       libswiftFoundation.dylib
PlugIn Version:          3.0.2 (800.0.63)

Date/Time:             2016-12-13 23:43:25.860 +0800
OS Version:            Mac OS X 10.11.6 (15G1108)
Report Version:        11
Anonymous UUID:        6E8AEBAE-0AF8-D350-66D6-57EC500D69F5

Sleep/Wake UUID:       6E017B49-1A38-4D3A-AB8F-FD9E200B6286

Time Awake Since Boot: 110000 seconds
Time Since Wake:       10000 seconds

System Integrity Protection: enabled

Crashed Thread:        0  Dispatch queue: com.apple.main-thread

Exception Type:        EXC_BAD_ACCESS (SIGSEGV)
Exception Codes:       EXC_I386_GPFLT
Exception Note:        EXC_CORPSE_NOTIFY

Application Specific Information:
Performing @selector(saveScreenShot:) from sender NSMenuItem 0x7fd05a7329f0

Thread 0 Crashed:: Dispatch queue: com.apple.main-thread
0   libobjc.A.dylib                 0x00007fff946adcdc lookUpImpOrForward + 135
1   libobjc.A.dylib                 0x00007fff946a8591 objc_msgSend + 209
2   libsystem_blocks.dylib          0x00007fff9b684986 _Block_object_assign + 364
3   com.apple.Foundation            0x00007fff8dc21ca4 __copy_helper_block_ + 49
4   libsystem_blocks.dylib          0x00007fff9b68459d _Block_copy_internal + 325
5   libswiftFoundation.dylib        0x000000010178af95 _TToFC10Foundation12_SwiftNSData19enumerateByteRangesfT5usingFTSVVSC8_NSRangeGSpV10ObjectiveC8ObjCBool__T__T_ + 21
6   com.apple.Foundation            0x00007fff8db02a94 _NSWriteDataToFileWithExtendedAttributes + 742
7   com.apple.iphonesimulator       0x0000000100ffdc1e 0x100ff1000 + 52254
8   com.apple.iphonesimulator       0x0000000100ffdda9 0x100ff1000 + 52649
9   libsystem_trace.dylib           0x00007fff9a5bd07a _os_activity_initiate + 75
10  com.apple.AppKit                0x00007fff909d4dbd -[NSApplication sendAction:to:from:] + 460
11  com.apple.AppKit                0x00007fff909d4b57 -[NSMenuItem _corePerformAction] + 336
12  com.apple.AppKit                0x00007fff909d48b7 -[NSCarbonMenuImpl performActionWithHighlightingForItemAtIndex:] + 114
13  libsystem_trace.dylib           0x00007fff9a5bd07a _os_activity_initiate + 75
14  com.apple.AppKit                0x00007fff909d37a5 -[NSMenu performKeyEquivalent:] + 357
15  com.apple.AppKit                0x00007fff909d2949 -[NSApplication _handleKeyEquivalent:] + 920
16  com.apple.AppKit                0x00007fff908f90fe -[NSApplication sendEvent:] + 4274
17  com.apple.iphonesimulator       0x000000010100d151 0x100ff1000 + 115025
18  com.apple.AppKit                0x00007fff9075fdf2 -[NSApplication run] + 796
19  com.apple.AppKit                0x00007fff90729368 NSApplicationMain + 1176
20  libdyld.dylib                   0x00007fff99c955ad start + 1

Thread 1:: Dispatch queue: com.apple.libdispatch-manager
0   libsystem_kernel.dylib          0x00007fff97827efa kevent_qos + 10
1   libdispatch.dylib               0x00007fff9612d165 _dispatch_mgr_invoke + 216
2   libdispatch.dylib               0x00007fff9612cdcd _dispatch_mgr_thread + 52

Thread 2:: com.apple.NSEventThread
0   libsystem_kernel.dylib          0x00007fff97820f72 mach_msg_trap + 10
1   libsystem_kernel.dylib          0x00007fff978203b3 mach_msg + 55
2   com.apple.CoreFoundation        0x00007fff97319124 __CFRunLoopServiceMachPort + 212
3   com.apple.CoreFoundation        0x00007fff973185ec __CFRunLoopRun + 1356
4   com.apple.CoreFoundation        0x00007fff97317e38 CFRunLoopRunSpecific + 296
5   com.apple.AppKit                0x00007fff908c1d95 _NSEventThread + 149
6   libsystem_pthread.dylib         0x00007fff928a299d _pthread_body + 131
7   libsystem_pthread.dylib         0x00007fff928a291a _pthread_start + 168
8   libsystem_pthread.dylib         0x00007fff928a0351 thread_start + 13

Thread 3:
0   libsystem_kernel.dylib          0x00007fff978275e2 __workq_kernreturn + 10
1   libsystem_pthread.dylib         0x00007fff928a2578 _pthread_wqthread + 1283
2   libsystem_pthread.dylib         0x00007fff928a0341 start_wqthread + 13

Thread 4:
0   libsystem_kernel.dylib          0x00007fff978275e2 __workq_kernreturn + 10
1   libsystem_pthread.dylib         0x00007fff928a2578 _pthread_wqthread + 1283
2   libsystem_pthread.dylib         0x00007fff928a0341 start_wqthread + 13

Thread 5:
0   libsystem_kernel.dylib          0x00007fff978275e2 __workq_kernreturn + 10
1   libsystem_pthread.dylib         0x00007fff928a2578 _pthread_wqthread + 1283
2   libsystem_pthread.dylib         0x00007fff928a0341 start_wqthread + 13

Thread 6:
0   libsystem_kernel.dylib          0x00007fff978275e2 __workq_kernreturn + 10
1   libsystem_pthread.dylib         0x00007fff928a2578 _pthread_wqthread + 1283
2   libsystem_pthread.dylib         0x00007fff928a0341 start_wqthread + 13

Thread 7:
0   libsystem_kernel.dylib          0x00007fff978275e2 __workq_kernreturn + 10
1   libsystem_pthread.dylib         0x00007fff928a2578 _pthread_wqthread + 1283
2   libsystem_pthread.dylib         0x00007fff928a0341 start_wqthread + 13

Thread 0 crashed with X86 Thread State (64-bit):
  rax: 0x00007fff6382b2c0  rbx: 0x00007fff6384ce48  rcx: 0x021b77058d48fb89  rdx: 0x00007fff638545f8
  rdi: 0x00007fff6384ce48  rsi: 0x00007fff976efa45  rbp: 0x00007fff5ec0dc30  rsp: 0x00007fff5ec0dbe0
   r8: 0x0000000000000000   r9: 0x0000000000000001  r10: 0x00007fff93c7d1e0  r11: 0x00007fff6384ce48
  r12: 0x00007fff976efa45  r13: 0x0000000000000000  r14: 0x0000000000000001  r15: 0x00007ffffffffff8
  rip: 0x00007fff946adcdc  rfl: 0x0000000000010206  cr2: 0x00007fff93c7c000
Tericky Shih
fonte
3
@ Cœur Para ser justo, a pergunta que você está se referindo foi publicada um minuto antes desta pergunta, então dificilmente eu diria que é uma duplicata.
xoudini

Respostas:

106

A falha parece ocorrer devido a uma falha de segmentação, ou mais especificamente uma falha de proteção geral, ao chamar o saveScreenShot:seletor. Por que isso acontece pode depender de várias coisas, então é difícil dizer se uma reinstalação ajudaria.

Em qualquer caso, se a função de captura de tela (⌘S) no simulador causar o travamento, não há quase nada que você possa fazer a respeito. A melhor opção que você tem provavelmente é enviar um relatório de bug para a Apple .

Atualizar:

Acabei de atualizar para o GM 8.2, e eis que o ⌘S trava para mim também. Embora eu esteja recebendo em KERN_INVALID_ADDRESSvez de EXC_I386_GPFLT.

Uma solução alternativa, por enquanto, é copiar a tela e colar na visualização:

captura de tela

xoudini
fonte
29

Sim, infelizmente, isso é tropeçar em um bug no Foundation no OS X 10.11. Você não terá problemas se atualizar para o macOS Sierra.

Se você não pode atualizar para o Sierra agora, você ainda pode fazer capturas de tela da linha de comando:

xcrun simctl io booted screenshot <path to output file>

Isso é mencionado nas notas de versão do Xcode 8.2

O simulador pode travar ao salvar uma captura de tela ao ser executado no OS X El Capitan. (29182710) A falha não ocorre no macOS Sierra.

Jeremy Huddleston Sequoia
fonte
Entendi. Vou ficar com a versão 10.11.6 como você mencionou
Tericky Shih
Que bela nota de lançamento, seja o que for que a Apple diga, ninguém reclamará.
teapeng
9
Sim, desculpe por isso. O problema não foi percebido até que fosse tarde demais para incluir uma solução alternativa. Adicionamos uma nota de lançamento para aumentar a conscientização sobre o problema e informar os usuários sobre as soluções alternativas.
Jeremy Huddleston Sequoia
Por precaução, com o caminho para a área de trabalho (como o comportamento original de "Salvar captura de tela") -> xcrun simctl io booted screenshot ~ / Desktop / filename.png
Dren
20

Encontre as etapas abaixo para obter a captura de tela.

1) Vá para Simuladores -> Editar -> Copiar tela ou você pode usar o atalho ( ctrl + cmd + c ).
2) Abra o Preview e vá em File -> New from Clipboard ou você pode usar o atalho ( cmd + n ).
3) Agora vá para Arquivo -> Salvar ou você pode usar o atalho ( cmd + s ).

Ou você também pode consultar a apresentação GIF abaixo.

GIF

Ramkrishna Sharma
fonte
4

Portanto, uma solução mais fácil é esta:

  1. Execute o aplicativo no simulador (obviamente)

  2. No simulador, vá em Editar> Copiar tela

  3. Abra o aplicativo de visualização
  4. Volte para o simulador e salve a captura de tela, ou seja, Arquivo> Salvar captura de tela

Feito!

Não sei por que isso impede que o bug ocorra, mas funcionou para mim. É mais rápido do que todos os outros métodos descritos acima.

Salil Junior
fonte
4

Solução 1

1) Vá para Simuladores> Editar> Copiar tela (⌃⌘C)

insira a descrição da imagem aqui

2) Abra o aplicativo de visualização> Vá para Arquivo> Novo da área de transferência (⌘N) e salve (⌘S) no seu local favorito em sua máquina

insira a descrição da imagem aqui

Solução 2: - Usando o utilitário de linha de comando xcrun Xcode

Abra Terminal Appe execute o seguinte comando para fazer a captura de tela

xcrun simctl io booted screenshot

Se você deseja salvar a imagem capturada em um local específico

xcrun simctl io booted screenshot <path_to_output_file>

MilanPanchal
fonte
2

Outra maneira conveniente -> Shift + Command + 4 - toque na barra de espaço, toque na janela para obter um instantâneo da janela do Simulador.

https://support.apple.com/en-us/HT201361

Benc
fonte