He estado golpeando mi cabeza contra la pared tratando de descubrir cómo tuve una pérdida de memoria en una aplicación de basura recolectada de Cocoa. (El uso de la memoria en Activity Monitor simplemente crecerá y crecerá, y ejecutar la aplicación utilizando los instrumentos del GC Monitor también mostrará un gráfico en constante crecimiento.)Fuga de memoria con la recolección de basura de Cocoa
Finalmente lo reduje a un solo patrón en mi código. Los datos se cargaban en un NSData y luego se analizaban mediante una biblioteca C (los bytes y la longitud de los datos se pasaban a él). La biblioteca C tiene devoluciones de llamada que dispararían y devolverían punteros y longitudes de inicio de subcadena (para evitar la copia interna). Sin embargo, para mis propósitos, necesitaba convertirlos en NSStrings y mantenerlos por un tiempo. Hice esto usando el método initWithBytes: length: encoding: de NSString. Supuse que copiaría los bytes y NSString lo manejaría de manera adecuada, pero algo está yendo mal porque esto se pierde como loco.
Este código se "fuga" o de alguna manera engañar al recolector de basura:
- (void)meh
{
NSData *data = [NSData dataWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"holmes" ofType:@"txt"]];
const int substrLength = 80;
for (const char *substr = [data bytes]; substr-(const char *)[data bytes] < [data length]; substr += substrLength) {
NSString *cocoaString = [[NSString alloc] initWithBytes:substr length:substrLength encoding:NSUTF8StringEncoding];
[cocoaString length];
}
}
puedo poner esto en temporizador y simplemente ver el uso de memoria subir y subir con el Monitor de actividad, así como con el instrumento GC monitor . (holmes.txt es 594 KB)
Este no es el mejor código del mundo, pero muestra el problema. (Estoy ejecutando 10.6, el proyecto está dirigido a 10.5 - si eso importa). Leí los documentos de la recolección de basura y noté una serie de posibles dificultades, pero no creo que esté haciendo nada obviamente en contra de las reglas aquí. Sin embargo, no está de más preguntar. ¡Gracias!
Así es una foto de la gráfico de objetos sólo crece y creciente:
No puedo ver ninguna fuga cuando la ejecuto, oscila entre 7,5 MB y 9 MB de uso de memoria después de varios minutos de funcionamiento. –
Eso es raro. Estoy en 10.6.2. Construí depuración y lanzamiento. Veo la memoria en constante crecimiento en todos los casos. wtf ... – Sean
Ahora he tenido a otra persona en 10.5 ejecutarlo, y él informa que tampoco parece estar creciendo para él. Necesito a alguien más en 10.6+ para probarlo. – Sean