首先来给大家看一小段代码:
for (int i = 0; i < someLargeNumber; i++) {
NSString *string = @”Wws”;
string = [string lowercaseString];
string = [string stringByAppendingString:@"sss"];
NSLog(@“%@”, string);
}
您看了可能会说,这没什么问题啊,MRC、ARC完全可以运行。(您要看出来了当我没说哈)
当给的someLargeNumber不是很大时,没有问题。如果给了一个很大的数的时候,内存泄露。为什么呢?
在ARC模式下编程,虽然会自动释放内存,但其机制是全局自动释放池(既RunLoop的释放池),在RunLoop释放池等待这个事件处理之后时释放。全局的自动释放池是当完成一次消息循环才会释放。所以当我们使用for循环创建很多个使用autorelease方式创建的NSString对象的时候,将所有的对象的释放权都交给了一个全局的释放池来处理。所以会导致对象无法及时释放,堆积在内存造成内存泄露。
修改如下:
for(int i = 0; i<1000;i++){
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
NSString *string = @"Wws";
string = [string lowercaseString];
string = [string stringByAppendingString:@"sss"];
NSLog(@"%@",string);
//释放池
[pool1 drain];
}
So,添加一个局部自动释放池就解决了。
回马枪。
for (int i = 0; i < someLargeNumber; i++) {
NSString *string = @”Wws”;
string = [string lowercaseString];
string = [string stringByAppendingString:@"sss"];
NSLog(@“%@”, string);
}
您看了可能会说,这没什么问题啊,MRC、ARC完全可以运行。(您要看出来了当我没说哈)
当给的someLargeNumber不是很大时,没有问题。如果给了一个很大的数的时候,内存泄露。为什么呢?
在ARC模式下编程,虽然会自动释放内存,但其机制是全局自动释放池(既RunLoop的释放池),在RunLoop释放池等待这个事件处理之后时释放。全局的自动释放池是当完成一次消息循环才会释放。所以当我们使用for循环创建很多个使用autorelease方式创建的NSString对象的时候,将所有的对象的释放权都交给了一个全局的释放池来处理。所以会导致对象无法及时释放,堆积在内存造成内存泄露。
修改如下:
for(int i = 0; i<1000;i++){
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
NSString *string = @"Wws";
string = [string lowercaseString];
string = [string stringByAppendingString:@"sss"];
NSLog(@"%@",string);
//释放池
[pool1 drain];
}
So,添加一个局部自动释放池就解决了。
回马枪。