Voici ce que nous faisons:
- Laisser l'iPhone gérer son propre vidages sur incident par le biais de l' existant App Store mécanismes. Mise à jour: ayant trouvé iTunes Connect pour ne pas être fiables à fournir des rapports de plantage, j'ai commencé à utiliser Crittercism et arceau de sécurité dans certaines de mes applications. Il ne le travail est bien fait, et a un plan gratuit.
- Notre produit sorti a aucune trace dans, ce qui semble cohérent avec ce que la plupart des autres applications de l'iPhone ne.
- Si un bug est signalé alors nous le reproduisons à l'aide d'un tracé de construire.
Plus en détail:
- Nous avons définir des macros pour NSLog trace dans de nombreux et différents niveaux de granularité.
- Utiliser Xcode construire des paramètres pour modifier le niveau de trace, qui contrôle la quantité de trace sera compilé dans le produit, il y a par exemple Release et Debug configurations.
- Si pas de trace de niveau est défini ensuite nous montrer plein de trace dans le Simulateur, et aucune trace lors de l'exécution sur un Périphérique réel.
J'ai inclus un exemple de code ci-dessous montre comment nous avons écrit ceci, et à quoi ressemble la sortie.
Nous définir plusieurs niveaux de suivi qui permet aux développeurs d'identifier les lignes de trace sont importants, et peuvent filtrer le détail des niveaux inférieurs si ils le veulent.
Exemple de code:
- (void)myMethod:(NSObject *)xiObj
{
TRC_ENTRY;
TRC_DBG(@"Boring low level stuff");
TRC_NRM(@"Higher level trace for more important info");
TRC_ALT(@"Really important trace, something bad is happening");
TRC_ERR(@"Error, this indicates a coding bug or unexpected condition");
TRC_EXIT;
}
Exemple de trace de sortie:
2009-09-11 14:22:48.051 MyApp[3122:207] ENTRY:+[MyClass myMethod:]
2009-09-11 14:22:48.063 MyApp[3122:207] DEBUG:+[MyClass myMethod:]:Boring low level stuff
2009-09-11 14:22:48.063 MyApp[3122:207] NORMAL:+[MyClass myMethod:]:Higher level trace for more important info
2009-09-11 14:22:48.063 MyApp[3122:207] ALERT:+[MyClass myMethod:]:Really important trace, something bad is happening
2009-09-11 14:22:48.063 MyApp[3122:207] ERROR:+[MyClass myMethod:]:Error, this indicates a coding bug or unexpected condition
2009-09-11 14:22:48.073 MyApp[3122:207] EXIT:+[MyClass myMethod:]
Nos définitions de trace:
#ifndef TRC_LEVEL
#if TARGET_IPHONE_SIMULATOR != 0
#define TRC_LEVEL 0
#else
#define TRC_LEVEL 5
#endif
#endif
/*****************************************************************************/
/* Entry/exit trace macros */
/*****************************************************************************/
#if TRC_LEVEL == 0
#define TRC_ENTRY NSLog(@"ENTRY: %s:%d:", __PRETTY_FUNCTION__,__LINE__);
#define TRC_EXIT NSLog(@"EXIT: %s:%d:", __PRETTY_FUNCTION__,__LINE__);
#else
#define TRC_ENTRY
#define TRC_EXIT
#endif
/*****************************************************************************/
/* Debug trace macros */
/*****************************************************************************/
#if (TRC_LEVEL <= 1)
#define TRC_DBG(A, ...) NSLog(@"DEBUG: %s:%d:%@", __PRETTY_FUNCTION__,__LINE__,[NSString stringWithFormat:A, ## __VA_ARGS__]);
#else
#define TRC_DBG(A, ...)
#endif
#if (TRC_LEVEL <= 2)
#define TRC_NRM(A, ...) NSLog(@"NORMAL:%s:%d:%@", __PRETTY_FUNCTION__,__LINE__,[NSString stringWithFormat:A, ## __VA_ARGS__]);
#else
#define TRC_NRM(A, ...)
#endif
#if (TRC_LEVEL <= 3)
#define TRC_ALT(A, ...) NSLog(@"ALERT: %s:%d:%@", __PRETTY_FUNCTION__,__LINE__,[NSString stringWithFormat:A, ## __VA_ARGS__]);
#else
#define TRC_ALT(A, ...)
#endif
#if (TRC_LEVEL <= 4)
#define TRC_ERR(A, ...) NSLog(@"ERROR: %s:%d:%@", __PRETTY_FUNCTION__,__LINE__,[NSString stringWithFormat:A, ## __VA_ARGS__]);
#else
#define TRC_ERR(A, ...)
#endif
Xcode paramètres:
Dans Xcode construire des paramètres, choisissez "Ajouter un Paramètre Défini par l'Utilisateur" (en cliquant sur le petit rouage en bas à gauche de la configuration de l'écran), puis de définir un nouveau paramètre appelé GCC_PREPROCESSOR_DEFINITIONS
et lui donner la valeur TRC_LEVEL=0
.
La seule subtilité est que Xcode ne sait pas faire un build propre si vous modifiez ce paramètre, donc n'oubliez pas de faire manuellement un Nettoyage si vous le changez.