内存管理1retain和release

简介:

Student.h:

#import <Foundation/Foundation.h>   @interface Student : NSObject  @property int age;  //默认会生成一个_age属性  @end

Student.m:

#import "Student.h"  @implementation Student //@synthesize age=_age;//xcode4.5中可以不使用synthesise方法,直接在头文件中使用property方法即可 //如果只在m文件中定义而没有在h文件中申明的方法属于privte方法,如果不写类型一般默认是protected方法 -(void)dealloc{  //构造父类的回收方法     NSLog(@"%@被销毁了",self);     NSLog(@"_age %i",_age);     [super dealloc];//一定要调用super的dealloc方法,最好放在最后面调用 } @end

main:

#import <Foundation/Foundation.h> #import "Student.h"  int main(int argc, const char * argv[]) {      @autoreleasepool {         Student *stu=[[[Student alloc] init] autorelease];  //alloc方法计数器为1         [stu retain];//调用一次retain方法计数器加1         NSLog(@"retaincount is %zi",[stu retainCount]);         [stu release];//调用一次release方法计数器减1         NSLog(@"retaincount is %zi",[stu retainCount]);         stu.age=10;         [stu retain];//add 1         //这儿retainCount返回的是Unsigned long 无符号长整形 %z代表无符号         NSLog(@"retaincount is %zi",[stu retainCount]);         NSLog(@"Student age is %i",[stu age]);         [stu release];  //计数器为0就调用dealloc方法     }     return 0; } 

结果:

2013-08-02 14:57:25.342 内存管理1retainrelease[788:303] retaincount is 2

2013-08-02 14:57:25.344 内存管理1retainrelease[788:303] retaincount is 1

2013-08-02 14:57:25.344 内存管理1retainrelease[788:303] retaincount is 2

2013-08-02 14:57:25.344 内存管理1retainrelease[788:303] Student age is 10

2013-08-02 14:57:25.345 内存管理1retainrelease[788:303] <Student: 0x100109a90>被销毁了

2013-08-02 14:57:25.345 内存管理1retainrelease[788:303] _age 10























本文转自蓬莱仙羽51CTO博客,原文链接:http://blog.51cto.com/dingxiaowei/1366576,如需转载请自行联系原作者

相关文章
|
8月前
|
存储 编译器 C语言
【C语言】VS实⽤调试技巧&(Debug和Release)监视&内存2
【C语言】VS实⽤调试技巧&(Debug和Release)监视&内存
|
8月前
|
程序员 C语言 C++
【C语言】VS实⽤调试技巧&(Debug和Release)监视&内存1
【C语言】VS实⽤调试技巧&(Debug和Release)监视&内存
|
存储 编译器 Serverless
iOS-底层原理 33:内存管理(一)TaggedPointer/retain/release/dealloc/retainCount 底层分析
iOS-底层原理 33:内存管理(一)TaggedPointer/retain/release/dealloc/retainCount 底层分析
270 0
iOS-底层原理 33:内存管理(一)TaggedPointer/retain/release/dealloc/retainCount 底层分析
|
2月前
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
532 1
|
1月前
|
存储 监控 算法
深入探索Java虚拟机(JVM)的内存管理机制
本文旨在为读者提供对Java虚拟机(JVM)内存管理机制的深入理解。通过详细解析JVM的内存结构、垃圾回收算法以及性能优化策略,本文不仅揭示了Java程序高效运行背后的原理,还为开发者提供了优化应用程序性能的实用技巧。不同于常规摘要仅概述文章大意,本文摘要将简要介绍JVM内存管理的关键点,为读者提供一个清晰的学习路线图。
|
2月前
|
Java
JVM内存参数
-Xmx[]:堆空间最大内存 -Xms[]:堆空间最小内存,一般设置成跟堆空间最大内存一样的 -Xmn[]:新生代的最大内存 -xx[use 垃圾回收器名称]:指定垃圾回收器 -xss:设置单个线程栈大小 一般设堆空间为最大可用物理地址的百分之80
|
2月前
|
Java
JVM运行时数据区(内存结构)
1)虚拟机栈:每次调用方法都会在虚拟机栈中产生一个栈帧,每个栈帧中都有方法的参数、局部变量、方法出口等信息,方法执行完毕后释放栈帧 (2)本地方法栈:为native修饰的本地方法提供的空间,在HotSpot中与虚拟机合二为一 (3)程序计数器:保存指令执行的地址,方便线程切回后能继续执行代码
31 3
|
2月前
|
存储 缓存 监控
Elasticsearch集群JVM调优堆外内存
Elasticsearch集群JVM调优堆外内存
64 1
|
2月前
|
Arthas 监控 Java
JVM进阶调优系列(9)大厂面试官:内存溢出几种?能否现场演示一下?| 面试就那点事
本文介绍了JVM内存溢出(OOM)的四种类型:堆内存、栈内存、元数据区和直接内存溢出。每种类型通过示例代码演示了如何触发OOM,并分析了其原因。文章还提供了如何使用JVM命令工具(如jmap、jhat、GCeasy、Arthas等)分析和定位内存溢出问题的方法。最后,强调了合理设置JVM参数和及时回收内存的重要性。