Courir mon application dans le simulateur en vertu des instruments pour vérifier les fuites de mémoire, il semble indiquer une fuite dans ce bloc de code:L'outil de fuite de mémoire d'Instruments rencontre-t-il des problèmes avec les boucles «for»?
De toute évidence, dans cette boucle, je suis alloc/s'être initialisé un objet, mais le relâcher quand j'en ai fini avec. Je me demande si c'est juste un symptôme de la façon dont les instruments voient l'activité dans cette boucle, ou si je perds la tête (ou si je fais quelque chose d'autre complètement faux).
"messages" est renvoyé au délégué de cette classe et publié par cette classe. Il semble être bien géré par cette classe (l'accesseur pour cela libère l'ancien et conserve le nouveau, et le libère dans dealloc). Si des messages, ou une classe propriétaire de messages, étaient divulgués, je verrais un MSNutableArray apparaître comme une fuite, n'est-ce pas? – ChrisW
Le diable est dans les détails. Dans cette classe de délégué (une sous-classe UITableViewController), il crée des objets de sous-classe UITableViewCell personnalisés qui ne libéraient pas l'objet 'message' qui leur avait été donné. Appréciez les commentaires, cependant, c'est ce qui m'a fait creuser! – ChrisW