AutoReleasePool

autoreleasepool并不是总是被auto 创建,然后自动维护应用创建的对象。

自动创建的情况如下:

1. 使用NSThread的detachNewThreadSelector:toTarget:withObject:方法创建新线程时,新线程自动带有autoreleasepool。

2. Main thread of Cocoa Application

以下情况需要开发者创建:

1. 在使用Dispatch Queue时, 虽然其Pool中每个thread都会有autoreleasepool,但是如果我们给的task每个都创建一些对象,并做autorelease,那若提交的task太多,比如有100000个,那在thread退出前,这些内存都无法释放,等于说有大量内存被占用而释放不了,也类似于leak了,所以这时,最好每个提交的task都有自己的autoreleasepool,task完成了,对象也释放了,下次再用,再分配,再释放。

2. 跟1类似的,如果没有函数内部有loop,并且每个loop都创建很多对象,如果希望这些对象早点释放,就可以自己创建autoreleasepool

分析一下现有API的行为。

NSString的方法:stringWithCString:encoding:,它创建了一个NSString对象返回了,但是它的方法名中没有Create和Copy,意味着调用者并不是这个新建对象的owner。那这个新建对象怎么release呢?autoreleasepool必是其神秘之处,下面一点点说说它。stringWithCString:encoding:这个方法内部没有autoreleasepool,但假设外部的某个方法是在autoreleasepool中的,这个新建对象会在外部的autoreleasepool退出时被释放。而Foundation/Cocoa很多方法都是这样的,就是因为它整体上依赖一个autoreleasepool的嵌套。

#import <Foundation/Foundation.h>
#include <pthread.h> void dosth(void *p)
{
{
int it = ;
while ( it < )
{
[NSString stringWithCString:"ajeiauwirejafs" encoding:NSUTF8StringEncoding];
it++;
}
}
} void * dosth2(void *p)
{
{
int it = ;
while ( it < )
{
[NSString stringWithCString:"ajeiauwirejafs" encoding:NSUTF8StringEncoding];
it++;
}
}
return NULL;
}
int main(int argc, const char * argv[])
{ @autoreleasepool { for (int i = ; i<; i++) {
[NSThread detachNewThreadSelector:@selector(dosth) toTarget:NULL withObject:NULL];
pthread_t pid;
pthread_create(&pid, NULL, dosth2,NULL);
sleep();
}
// insert code here...
NSLog(@"Hello, World!"); } return ;
}

ARC(Automatic Reference Counting)

AutoReleasePool确实很好用,不过Apple更推荐ARC(Automatic Reference Counting)。本文的重点是能区分AutoReleasePool和ARC,并不详尽介绍ARC。

Automatic Reference Counting (ARC) is a compiler feature that provides automatic memory management of Objective-C objects. ARC works by adding code at compile time to ensure that objects live as long as necessary, but no longer. Conceptually, it follows the same memory management conventions as manual reference counting by adding the appropriate memory management calls for you.

也就是说ARC是由编译器在编译后的代码中假如retain/release的调用,编译器可以让临时对象的生命周期刚刚好,不会过早被release,也不会这个对象不再需要后很久才释放。概念上说,ARC跟手动管理一样的,但是实际上还是有很多差别的,比如:既然编译器会插入Release/Retain代码,那程序中就不允许调用retain,release, autorelease等方法了,不然就会造成内存管理的混乱,但是CFRelease,CFRetain还是可以用的【也就是说,ARC只管ObjectiveC那部分,而管不了C,CoreFoundation那部分】。Wiki上总结了在使用ARC时,有哪些API不可以调用,哪些又必须用。

其中一项是:

“There is no casual casting between id and void *.

You must use special casts that tell the compiler about object lifetime. You need to do this to cast between Objective-C objects and Core Foundation types that you pass as function arguments”

也就是说在将OBJC object和CoreFoundation的对象之间Cast时,必须用特殊的cast操作符进行。

  • __bridge transfers a pointer between Objective-C and Core Foundation with no transfer of ownership.

  • __bridge_retained or CFBridgingRetain casts an Objective-C pointer to a Core Foundation pointer and also transfers ownership to you.

    You are responsible for calling CFRelease or a related function to relinquish ownership of the object.

  • __bridge_transfer or CFBridgingRelease moves a non-Objective-C pointer to Objective-C and also transfers ownership to ARC.

    ARC is responsible for relinquishing ownership of the object.

上面说ARC只管ObjC的对象,不管C/CF的对象,如果一个对象在CF中创建,要拿到ObjC中使用,如果希望ARC接管这个对象,那就使用__bridge_transfer or CFBridgingRelease,如果不希望由ARC接管,那就用__bridge。如果一个对象在ObjC中创建,要拿到CF中使用,并由CF/C释放,那就得使用__bridge_retained or CFBridgingRetain,如果还继续由ARC管理,就使用__bridge.

其他的关于ARC的使用限制,就在要使用时一一查看吧,本文对ARC讲到这里,应该已经很清楚ARC跟autoreleasepool的关系了。

Garbage Collection

ObjC 2.0 provided an optional conservative, generational garbage collector. 如果enable了garbage collection,那么runtime会将retain/release转成空操作,所有的ObjC对象都可以被回收,而C的对象可以用__strong标记符让GC回收;A zero-ing weak subsystem was also provided such that pointers marked as "__weak" are set to zero when the object (or more simply, GC memory) is collected.但是GC在iOS上performance不好,从来都没有enable过,而且在OS X 10.8上也会设置为deprecated,将来会从OSX中移除。

Reference:

ARC:https://developer.apple.com/library/mac/releasenotes/ObjectiveC/RN-TransitioningToARC/Introduction/Introduction.html#//apple_ref/doc/uid/TP40011226

ARC:http://clang.llvm.org/docs/AutomaticReferenceCounting.html

ARC: http://en.wikipedia.org/wiki/Automatic_Reference_Counting

AutoReleasePool 和 ARC 以及Garbage Collection的更多相关文章

  1. Python Garbage Collection 与 Objective-C ARC

    转载请注明出处 http://blog.csdn.net/u014205968/article/details/69389363 Python GC 与 Objective-C ARC 提起GC(Ga ...

  2. Unity性能优化(3)-官方教程Optimizing garbage collection in Unity games翻译

    本文是Unity官方教程,性能优化系列的第三篇<Optimizing garbage collection in Unity games>的翻译. 相关文章: Unity性能优化(1)-官 ...

  3. How Garbage Collection Really Works

    Java Memory Management, with its built-in garbage collection, is one of the language's finest achiev ...

  4. Java Garbage Collection Basics--转载

    原文地址:http://www.oracle.com/webfolder/technetwork/tutorials/obe/java/gc01/index.html Overview Purpose ...

  5. [翻译]Java垃圾收集精粹(Java Garbage Collection Distilled)

    source URL: http://www.infoq.com/articles/Java_Garbage_Collection_Distilled Name: Java Garbage Colle ...

  6. The Impact of Garbage Collection on Application Performance

    As we’ve seen, the performance of the garbage collector is not determined by the number of dead obje ...

  7. [Java] 垃圾回收 ( Garbage Collection ) 的步骤演示

    关于 JVM 垃圾回收机制的基础内容,可参考上一篇博客 垃圾回收机制 ( Garbage Collection ) 简介 上一篇博客,介绍了堆的内存被分为三个部分:年轻代.老年代.永生代.这篇博文将演 ...

  8. [Java] 垃圾回收机制 ( Garbage Collection ) 简介

    自动垃圾回收( Automatic Garbage Collection ) 自动垃圾回收,是指在堆(Heap)内存上分辨哪些对象还在被使用,哪些对象没有被使用,并清除没有被使用的对象.所以,这里的垃 ...

  9. 【python进阶】Garbage collection垃圾回收1

    前言 GC垃圾回收在python中是很重要的一部分,同样我将分两次去讲解Garbage collection垃圾回收,此篇为Garbage collection垃圾回收第一篇,下面开始今天的说明~~~ ...

随机推荐

  1. eclipse插件在线发布发布和版本更新(web site) 转

    欢迎关注我的社交账号: 博客园地址: http://www.cnblogs.com/jiangxinnju/p/4781259.html GitHub地址: https://github.com/ji ...

  2. C语言中随机数相关问题

    用C语言产生随机数重要用到rand函数.srand函数.及宏RAND_MAX(32767),它们均在stdlib.h中进行了声明. int rand(void);//生成一个随机数 voidsrand ...

  3. 【bzoj1040】骑士

    [bzoj1040]骑士 题意 给定一个基环森林,求最大独立集. 分析 其实这是一道一年前做过的题. 只是今天在看bzoj1023的时候突然来了几许兴致,回过头来看一看. 如果对于一棵树的最大独立集, ...

  4. 字符串(string)转json

    第一种方式: 使用js函数eval(); testJson=eval(testJson);是错误的转换方式. 正确的转换方式需要加(): testJson = eval("(" + ...

  5. PHP Warning: ob_start() : output handler 'ob_gzhandler conflicts with 'zlib output compression'

    安装phpcms过程中,会遇到Warning:  ob_start() : output handler 'ob_gzhandler conflicts with 'zlib output compr ...

  6. 131. 132. Palindrome Partitioning *HARD* -- 分割回文字符串

    131. Palindrome Partitioning Given a string s, partition s such that every substring of the partitio ...

  7. 手动实现KVO

    前言 KVO(Key-Value Observing, 键值观察), KVO的实现也依赖于runtime. 当你对一个对象进行观察时, 系统会动态创建一个类继承自原类, 然后重写被观察属性的sette ...

  8. OC 实例变量(Instance Var)和成员变量(member var)区别

    摘要:  Objective-C  引入了“实例变量"的概念,但同时, 也经常出现 “成员变量”的声音. 到底什么是实例变量,什么是成员变量,二者的区别是什么呢? 今天查看apple 的官方 ...

  9. DOI EXCEL显示报表

    我这个是比较不规则的数据填充 1.程序开头,定义一个工作区,存对应单元格的值: BEGIN OF TY_EXCEL, C031() TYPE C, C032() TYPE C, C033() TYPE ...

  10. Linux Mysql 1130错误解决

      今天在win32下通过navicat 远程登录Mysql时出现如下错误:     想都不用想,肯定是Mysql的访问权限问题.   首先,通过终端(我用的是SSH)远程登录到Linux服务器,为了 ...