iOS 优化内存(四)何时用self

iOS何时使用self.

大多数的答案是:“这与objc的存取方法有关”

怎么样才能有关呢?接下来通过几个小例子来看一下。

首先我们创建一个学生类:Student类

这个学生类里有学生的id和学生的姓名name

  1. #import
  2. @interface
  3. Student : NSObject{
  4. //idname
  5. NSString *id;
  6. NSString *name;
  7. }
  8. @property
  9. (nonatomic,strong) NSString *id;
  10. @property
  11. (nonatomic,strong) NSString *name;
  12. @end
  13. 学生类的实现文件
  14. #import
  15. "Student.h"
  16. @implementation
  17. Student
  18. @synthesize
  19. id,name;
  20. @end

如果使用上面的方法来定义学生类的属性的get、set方法的时候,那么其他类访问的时候就是:

获取student的名字通过student.name来获取,给名字赋值则使用[student

setName:@“eve”]; 其中student是Student类的对象,如果在Student类内部访问其成员属性使用[self

setName:@”evo”], 访问使用self.name;

上面的方法只是一种,但是很难解释self该不该使用。请看下面:

我们改写Student类

  1. #import
  2. @interface
  3. Student : NSObject{
  4. //idname
  5. NSString *_id;
  6. NSString *_name;
  7. }
  8. @property
  9. (nonatomic,strong) NSString *id;
  10. @property
  11. (nonatomic,strong) NSString *name;
  12. @end
  13. .m文件
  14. #import
  15. "Student.h"
  16. @implementation
  17. Student
  18. @synthesize
  19. id = _id;
  20. @synthesize
  21. name = _name;
  22. @end

可见这样的写法我们增加了_id和_name,其中@synthesize也有一定的变化。

如何这个时候使用self.name编译器就会报错,这样就说明了我们通常使用self.name实际使用的是student类name的get方法,同理name的set方法亦是如此。

另外网络上也有人从内存管理方面来说明的,我将其剪切出来以供学习:

ViewController.h文件,使用Student类,代码如下:

  1. #import
  2. @
  3. class Student;
  4. @
  5. interface ViewController : UIViewController{
  6. Student *_student;
  7. }
  8. @property
  9. (nonatomic, retain) Student *student;
  10. @end
  11. ViewController.m文件,代码:
  12. #import
  13. "ViewController.h"
  14. #import
  15. "Student.h"
  16. @implementation
  17. ViewController
  18. @synthesize
  19. student = _student;
  20. -
  21. (void)didReceiveMemoryWarning
  22. {
  23. [super didReceiveMemoryWarning];
  24. }
  25. #pragma
  26. mark - View lifecycle
  27. -
  28. (void)viewDidLoad
  29. {
  30. [super viewDidLoad];
  31. }
  32. -
  33. (void) dealloc
  34. {
  35. [_student release];
  36. _student = nil;
  37. [super dealloc];
  38. }
  39. 其它的方法没有使用到,所以这里就不在显示了。
  40. 在ViewController.m的viewDidLoad方法中创建一个Student类的对象
  41. Student
  42. *mystudent = [[Student alloc] init];
  43. self.student
  44. = mystudent;
  45. [mystudent
  46. release];

接下来就需要从内存角度来分析它们之间的区别了:

1、加self的方式:

  1. Student
  2. *mystudent = [[Student alloc] init];  //mystudent 对象
  3. retainCount = 1;
  4. self.student
  5. = mystudent; //student 对象 retainCount = 2;
  6. [mystudent
  7. release];//student 对象 retainCount = 1;
  8. retainCount指对象引用计数,student的property
  9. 是retain 默认使用self.student引用计数+1。

2、不加self的方式

  1. Student
  2. *mystudent = [[Student alloc] init];  //mystudent 对象
  3. retainCount = 1;
  4. student
  5. = mystudent; //student 对象 retainCount = 1;
  6. [mystudent
  7. release]; //student 对象内存已释放,如果调用,会有异常

3、加self直接赋值方式

self.student = [[Student alloc] init];//student 对象 retainCount =

2;容易造成内存泄露

由于objective-c内存管理是根据引用计数处理的,当一个对象的引用计数为零时,gcc才会释放该内存

个人总结:只需要在属性初始化的时候使用self.属性,其他时候直接使用属性名就行;使用self.是 使retaincount+1,为了确保当前类对此属性具有拥有权

个人使用习惯:

  1. @interface CustomClass : UIViewController
  2. {
  3. NSString *str
  4. }
  5. @property (retain, nonatomic) NSString *str; @implementation CustomClass @synthesize str; -(void)viewDidLoad
  6. { //方法一  用alloc必须手动释放一次 self.str  =  [[NSString alloc]initWithString:@"my str"];
  7. [str release]; //方法二 用类方法不用 self.str =     [NSString stringWithString:@"my str"];
  8. 以后调用时直接使用str,不必使用self.str
  9. [str appendString:@"\n"];
  10. } //在dealloc中必须释放 - (void)dealloc
  11. { //方法一  [str release];
  12. str = nil; //方法二 self.str = nil;
  13. [super dealloc];
  14. }
时间: 2024-10-10 00:10:05

iOS 优化内存(四)何时用self的相关文章

iOS优化内存方法推荐

1. 用ARC管理内存 ARC(Automatic ReferenceCounting, 自动引用计数)和iOS5一起发布,它避免了最常见的也就是经常是由于我们忘记释放内存所造成的内存泄露.它自动为你管理retain和release的过程,所以你就不必去手动干预了.忘掉代码段结尾的release简直像记得吃饭一样简单.而ARC会自动在底层为你做这些工作.除了帮你避免内存泄露,ARC还可以帮你提高性能,它能保证释放掉不再需要的对象的内存. 2. 在正确的地方使用 reuseIdentifier 一

iOS 优化内存(五)开发流程总结

iOS开发流程总结 流程:注册.开发.真机测试.发布以及上线. iPhone iOS 4从注册到app上线开发流程 一.关于注册账号IDP和Apple ID: 1.注册App ID(无论是iOS使用者还是开发者都需要*****ID,只是后者还需要付99$注册成为开发者.) 网址:http://developer.apple.com 由于上边的网址没有注册按钮,所以去iTunes注册,方法参照(这里注册的是免费的,您需要注册付费的): http://jingyan.baidu.com/articl

iOS 优化内存(六)开发必不可少的75个工具

iOS 开发者必不可少的 75 个工具 如果你去到一位熟练的木匠的工作室,你总是能发现他/她有一堆工具来完成不同的任务. 软件开发同样如此.你可以从软件开发者如何使用工具中看出他水准如何.有经验的开发者精于使用工具.对你目前所使用的工具不断研究,同时了解一些替代品的使用,当你目前所用的工具无法满足你的需要时可以填补空缺. 记住了这些,我将向你展示一份关于各种工具的长长的列表.其中一些我每天都用,其他的我看情况使用.如果你还有更多的工具想展示在这个列表里,可以跟我留言哦亲. 我尽我所能给列表分分类

iOS 优化内存(三)iOS应用程序多语言本地化解决方案

iOS应用程序多语言本地化解决方案 最近要对一款游戏进行多语言本地化,在网上找了一些方案,加上自己的一点点想法整理出一套方案和大家分享! 多语言在应用程序中一般有两种做法: 一.程序中提供给用户自己选择的机会: 二.根据当前用户当前移动设备的语言自动将我们的app切换对应语言. 第一种做法比较简单完全靠自己的发挥了,这里主要讲第二种做法,主要分一下几点: 1.本地化应用程序名称 2.本地化字符串 3.本地化图片 4.本地化其他文件 1.本地化应用程序名称 (1)点击"new file"

iOS 优化内存(七)开发中使用第三方类库

在iOS中使用第三方类库 方法一:直接复制所有源文件到项目中 这种方法就是把第三方类库的所有源文件复制到项目中,直接把所有.h和.m文件拖到XCode项目中即可.如果第三方类库引用了一些系统自带类库,那么在项目中还需要额外引用那些类库. 如果当前的项目启用了ARC,而引用的第三方类库未使用ARC,那还需要在项目信息的Targets – Build Parses里找到第三方类库的.m文件,并为它们加上-fno-objc-arc标记. 而对于在未启用ARC的项目用引用使用了ARC的第三方类库,则需要

iOS 优化内存(八)持久化

iOS持久化 1.文件系统 不管是Mac OS X 还是iOS的文件系统都是建立在UNIX文件系统基础之上的. 1.1 沙盒模型 在iOS中,一个App的读写权限只局限于自己的沙盒目录中. 沙盒模型到底有哪些好处呢? 安全:别的App无法修改你的程序或数据 保护隐私:别的App无法读取你的程序和数据 方便删除:因为一个App所有产生的内容都在自己的沙盒中,所以删除App只需要将沙盒删除就可以彻底删除程序了 iOS App沙盒中的目录 App Bundle ,如xxx.app 其实是一个目录,里面

iOS项目内存优化

在用非ARC模式编写iOS程序的时候,造成程序内存泄露在所难免,后期我们一般会进行内存优化.自己比较常用的内存优化方法有两种 1.Analyze,静态分析内存泄露的方法.很简单,在Xcode菜单栏中点击 ”Product“ -> "Analyze",编译完成后项目工程中可能造成内存泄露的代码就会被标记出来,这样我们就可以有针对性的更改代码优化内存了. 2.使用Xcode的自带工具Leaks,动态的检测内存泄露.一般步骤如下. 1>在Xcode菜单栏中点击 ”Product“

cocos2d-x如何优化内存的应用

自身以前也写过cocos2d-x如何优化内存的应用,以及内存不够的情况下怎么样处置惩罚游戏.今天在微博中看到有友好简介了下内存,挺详细的.不晓得是谁写的,我纪录下. 一,IOS与图片内存 在IOS上,图片会被积极缩放到2的N次方大小.例如一张1024*1025的图片,占用的内存与一张1024*2048的图片是一致的.图片占用内存大小的共计的公式是:长*宽*4.何等一张512*512 占用的内存即是 512*512*4 = 1M.其他尺寸以此类推.(ps:IOS上支持的最大尺寸为2048*2048

iOS音频播放 (四):AudioFile 转

原文出处 : http://msching.github.io/blog/2014/07/19/audio-in-ios-4/ 前言 接着第三篇的AudioStreamFile这一篇要来聊一下AudioFile.和AudioStreamFile一样AudioFile是AudioToolBox framework中的一员,它也能够完成第一篇所述的第2步,读取音频格式信息和进行帧分离,但事实上它的功能远不止如此. AudioFile介绍 按照官方文档的描述: a C programming inte