Crash du simulateur Xcode 8.2 lors de l'enregistrement de la capture d'écran

103

Après la mise à jour de XCode 8.2, chaque fois que la capture d'écran du simulateur de sauvegarde le faisait planter. Même si je réinitialise le contenu et les paramètres, je plante toujours.

Dois-je supprimer tous les simulateurs et les réinstaller?

Mise à jour :

  • 8.2.1 a le même problème.
  • 8.3 uniquement Sierra pris en charge.

Voici le rapport de panne:

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
la source
3
@ Cœur Pour être honnête, la question à laquelle vous faites référence a été publiée une minute avant cette question, donc je ne l'appellerais guère un double.
xoudini

Réponses:

106

Le crash semble provenir d'un défaut de segmentation, ou plus précisément d'un défaut de protection générale, lors de l'appel du saveScreenShot:sélecteur. Pourquoi cela se produit peut dépendre de plusieurs choses, il est donc difficile de dire si une réinstallation aiderait.

Dans tous les cas, si la fonction de capture d'écran (⌘S) dans le simulateur provoque le crash, vous ne pouvez pratiquement rien y faire. La meilleure option est probablement de déposer un rapport de bogue à Apple .

Mettre à jour:

Je viens de mettre à jour la version 8.2 GM, et bas et voilà, ⌘S plante aussi pour moi. Bien que je reçois à la KERN_INVALID_ADDRESSplace de EXC_I386_GPFLT.

Une solution de contournement, pour le moment, consiste à copier l'écran et à le coller dans Aperçu:

capture d'écran

Xoudini
la source
29

Oui, malheureusement, cela trébuche sur un bogue dans Foundation sur OS X 10.11. Vous n'aurez pas le problème si vous passez à macOS Sierra.

Si vous ne pouvez pas mettre à niveau vers Sierra pour le moment, vous pouvez toujours prendre des captures d'écran à partir de la ligne de commande:

xcrun simctl io booted screenshot <path to output file>

Ceci est mentionné dans les notes de mise à jour de Xcode 8.2

Le simulateur peut se bloquer lors de l'enregistrement d'une capture d'écran lors de l'exécution sous OS X El Capitan. (29182710) Le plantage ne se produit pas sur macOS Sierra.

Jeremy Huddleston Séquoia
la source
Je l'ai. Je reste avec la version 10.11.6 comme vous le mentionnez
Tericky Shih
Quelle belle note de publication, quoi que dise Apple, personne ne se plaindra.
teapeng
9
Oui, désolé. Le problème n'a été remarqué qu'après qu'il était trop tard pour inclure une solution de contournement. Nous avons ajouté une note de publication pour sensibiliser le public au problème et informer les utilisateurs des solutions de contournement.
Jeremy Huddleston Sequoia
Juste au cas où, avec le chemin vers le bureau (comme le comportement d'origine de "Enregistrer la capture d'écran") -> xcrun simctl io booted screenshot ~ / Desktop / filename.png
Dren
20

Veuillez trouver les étapes ci-dessous pour obtenir la capture d'écran.

1) Allez dans Simulateurs -> Modifier -> Copier l'écran ou vous pouvez utiliser le raccourci ( ctrl + cmd + c ).
2) Ouvrez l' aperçu et allez dans Fichier -> Nouveau à partir du presse-papiers ou vous pouvez utiliser le raccourci ( cmd + n ).
3) Maintenant, allez dans Fichier -> Enregistrer ou vous pouvez utiliser le raccourci ( cmd + s ).

Ou vous pouvez également vous référer à la présentation GIF ci-dessous.

GIF

Ramkrishna Sharma
la source
4

Donc, une solution de contournement plus simple est la suivante:

  1. Exécutez l'application dans le simulateur (évidemment)

  2. Dans le simulateur, allez dans Edition> Copier l'écran

  3. Ouvrir l'application Aperçu
  4. Revenez au simulateur et enregistrez la capture d'écran ie Fichier> Enregistrer la capture d'écran

Terminé!

Je ne sais pas pourquoi cela empêche le bogue de se produire, mais cela a fonctionné pour moi. C'est plus rapide que toutes les autres méthodes décrites ci-dessus.

Salil Junior
la source
4

Solution 1

1) Allez dans Simulateurs> Modifier> Écran de copie (⌃⌘C)

entrez la description de l'image ici

2) Ouvrez l'application Aperçu> Allez dans Fichier> Nouveau à partir du presse-papiers (⌘N) et enregistrez (⌘S) dans votre emplacement préféré sur votre machine

entrez la description de l'image ici

Solution 2: - Utilisation de l'utilitaire de ligne de commande xcrun Xcode

Ouvrez Terminal Appet exécutez la commande suivante pour prendre une capture d'écran

xcrun simctl io booted screenshot

Si vous souhaitez enregistrer la capture d'écran capturée à un emplacement spécifique

xcrun simctl io booted screenshot <path_to_output_file>

MilanPanchal
la source
2

Un autre moyen pratique -> Shift + Commande + 4 - appuyez sur la barre d'espace, appuyez sur la fenêtre pour obtenir un instantané de la fenêtre du simulateur.

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

benc
la source