内存管理:

1.作用范围:

不论什么继承了NSObject的对象,堆基本数据类型无效如:int
a ,float price;;

2.原理:

每一个对象内部都保存了一个与之相关的整数,称为引用计数器,

当使用alloc  
new  
copy创建一个对象的时候,对象的引用计数器被设置为1

每给对象发送一次retain消息。能够使引用计数器+1

给对象发送一条release消息。能够使引用计数器-1

当一个对象的引用计数器为0时,那么它将被销毁。其占用的内存被系统回收,OC也会自己主动向对象发送一条dealloc消息,通常会重写dealloc方法,在这里,释放相关资源,一定不要直接调用dealloc方法:

能够给对象发送retaincount消息。获得当前的因数计数器数值。

3.retain
release

1。假设你想知道一个对象是不是被回收,方法:重写父类的dealloc方法:

注意:一定要调用super的dealloc方法,并且最后放在最后面调用。

([super
dealloc ])

2.假设一个对象调用了release
的操作。而且他的引用计数器已经为0。假设你再次调用他的release方法:这时候就会发生野指针错误:

野指针错误:你调用了本不属于你的内存空间,你既然已经释放了本来你的内存,那么如今那块内存已经不属于你了。你在调用release方法。说明你又声明那块内存是属于你的,这时候就会发生野指针
错误。

注意:当一个对象retain0的时候。这时候你就不能再调用他的retainCound方法。由于一个被释放的对象,没有内存。不再去进行訪问会发生野指针错误。

3.假设你在创建对象的时候。加上autorelease,那么编译器会在一个适当的时机释放对象,这                    
样就不须要你自己手动释放对象的内存了

4.内存管理法则:

1.谁创建,谁释放(“谁污染,谁治理”),假设你通过alloc
,new ,copy
来创建一个对象。那么你必须调用release或autorelease
,假设不是你创建的。你就不用去释放。

2.一般除了alloc
,new  copy
之外的方法创建的对象都被声明了autorelease

3.retain
,谁release
,仅仅要你调用了retain
,不管这个对象是怎样产生的,你都要调用release;

5.对象之间的内存管理:

前提:假设一个类A作为另外一个类B的成员变量。而且訪问A的数据成员的是否。假设在main函数中调用了类B的一个方法,这时候会调用A的对象进行初始化A的成员变量,当在该方法中销毁后。类B又訪问了一个方法2,这时候仍然让类A的对象进行初始化操作。这时候会出现野指针错误,

原因:因为在方法1中已经释放了A对象,所以A对象所指向的成员变量的内存回收,假设你再进行调用。就会指向一个不属于自己的内存空间,这是非常危急的。

解决的方法。在set方法里里面设施对象的retain操作。并进行release。前提。是推断传进来的对象是不是本身。假设是本身那就释放掉原来对象的指向,假设是一个新的,那就没有必要进行release,由于,新对象本来计数器为0.你再release,就会错误。

代码例如以下:

B
中的.M文件

- (id)initWithAge:(int)age{

if ( self= [super
init]) {

_age = age;

}

return self;

}

#pragma mark
回收对象

- (void)dealloc {

// 释放Book对象

[_book
release];

//[self.book release];

NSLog(@"student:%i被销毁了",
_age);

[super
dealloc];

}

#pragma mark - getter和setter

- (void)setBook:(Book*)book {

if (_book!= book) {

// 先释放旧的成员变量

[_book
release];

// 再retain新传进来的对象

_book = [book retain];

}

}

- (Book *)book {

return _book;

}

#pragma mark -
公共方法

#pragma mark
读书

- (void)readBook {

NSLog(@"当前读的书是:%f",
_book.price);

}

main函数:

void test(Student*stu) {

// book:1 
引用计数器

Book *book = [[Book
alloc] initWithPrice:3.5];

// book:2

stu.book = book;

// book:1

[book
release];

//book2:1

Book *book2 = [[Book
alloc] initWithPrice:4.5];

//book2:2

stu.book = book2;

// book2:2

stu.book = book2;

// book2:1

[book2
release];

// book2:1

stu.book = book2;//假设再次调用,book2的retaiin也不会变

}

void test1(Student*stu) {

[stu
readBook];

}

int main(intargc,
const char* argv[])

{

@autoreleasepool {

// stu:1

Student *stu = [[Student
];

// stu:1

//book:1

//book2:1

test(stu);

// stu:1

//book:1

//book2:1

test1(stu);

// stu:0

//book2:0

//book:1

[stu
release];

}

return ;

}

OC第三天(内存管理)的更多相关文章

  1. memcache(三)内存管理

    memcached(三)内存管理 memcached使用预申请的方式来管理内存的分配,从而避免内存碎片化的问题.如果采用mallo和free来动态的申请和销毁内存,必然会产生大量的内存碎片. 基本知识 ...

  2. 十天学Linux内核之第三天---内存管理方式

    原文:十天学Linux内核之第三天---内存管理方式 昨天分析的进程的代码让自己还在头昏目眩,脑子中这几天都是关于Linux内核的,对于自己出现的一些问题我会继续改正,希望和大家好好分享,共同进步.今 ...

  3. OC语言-05-OC语言-内存管理

    一.引用计数器 1> 栈和堆 栈 ① 主要存储局部变量 ② 内存自动回收 堆 ① 主要存储需要动态分配内存的变量 ② 需要手动回收内存,是OC内存管理的对象 2> 简介 作用 ① 表示对象 ...

  4. OC基础15:内存管理和自动引用计数

    "OC基础"这个分类的文章是我在自学Stephen G.Kochan的<Objective-C程序设计第6版>过程中的笔记. 1.什么是ARC? (1).ARC全名为A ...

  5. OC学习篇之---内存管理介绍和使用

    在之前的一片文章我们说了OC中谓词操作:http://blog.csdn.net/jiangwei0910410003/article/details/41923507,从今天开始我们就来看一下OC中 ...

  6. OC第七节——内存管理

    戏言: iOS开发已经到了一个ARC时代,一般不需要我们过多的去关注内存是怎么分配,怎么管理的.很长一段时间,我也不知道内存管理是什么鬼,但如果遇到这方面的问题,却找不到解决办法确实很头疼的.So,还 ...

  7. 三、内存管理单元---MMU

    3.1 MMU介绍 3.1.1 MMU 特性 内存管理单元(Memory Management Unit)简称MMU,它负责虚拟地址到物理地址的映射,并提供硬件机制的内存访问权限检查.现在的多用户多进 ...

  8. oc 第五天(内存管理)

    OC的重点: 内存管理 1 基本原理     OC的内存回收机制是和JAVA的自动回收机制是不同的,它有两种模式,或者准确的说是同 一种模式的两种不同体现,下面简单总结下. 1手动内存回收       ...

  9. 七.OC基础加强--1.内存管理 2.野指针,内存泄露 3.set方法的内存管理 4.@property参数 5.@class和循环retain的使用 6.NSString的内存管理

    1,内存管理简单介绍 1,为什么要有内存管理? malloc selloc dealloc```需要回头复习 一般的内存 4s 是512m内存:6 是1024m内存: 当内存过大时,会耗尽内存.出现程 ...

  10. windows的三种内存管理方法

    Windows的内存管理方法 windows提供了3种方法来进行内存管理: l         虚拟内存,最适合用来管理大型对象或者结构数组 l         内存映射文件,最适合用来管理大型数据流 ...

随机推荐

  1. sublime界面主题

    一直以来都是使用的SUBLIME,真的很强大. 最近刚转到linux来学习C,把它重新配置了一遍,默认的字体颜色的搭配已经很不错了.不过界面的样子还是不太习惯.重新安装了下soda这个主题包,惭愧!即 ...

  2. Spring整合JUnit4测试使用注解引入多个配置文件

    转自:https://kanpiaoxue.iteye.com/blog/2151903 我们使用spring写junit单测的时候,有的时候我们的spring配置文件只有一个.我们在类的注释上面会这 ...

  3. Hdu-6242 2017CCPC-哈尔滨站 M.Geometry Problem 计算几何 随机

    题面 题意:给你n个点,让你找到一个圆,输出圆心,和半径,使得有超过一半的点刚好在圆上.n<=1e5,题目保证了有解 题解:刚开始看着很不可做的样子,但是多想想,三点确定一个圆,三点啊! 现在有 ...

  4. 【Linux】YUM Repositories for CentOS, RHEL & Fedora Systems

    这里是官方wiki:https://wiki.centos.org/AdditionalResources/Repositories 一.简介 YUM(Yellowdog Updater Modifi ...

  5. HDU2034 人见人爱 A - B

    2019-05-17 09:37:46 加油,加油 !!! 结果要从小到大输出 NULL后面没有空格 m && n == 0才结束 注意:看题仔细,罚时很严重 #include < ...

  6. MySQL架构与SQL执行流程

    MySQL架构设计 下面是一张MySQL的架构图: 上方各个组件的含义如下: Connectors 指的是不同语言中与SQL的交互 Management Serveices & Utiliti ...

  7. O - Masha and Bears

    Problem description A family consisting of father bear, mother bear and son bear owns three cars. Fa ...

  8. 在django中应用装饰器(一)

    在新写的博客应用中,涉及很多关于权限的问题,比如修改用户信息,博客的修改与删除,虽然默认的提交信息都是session的用户,但是也应该防止一下篡改提交的可能,之前想的是在每个view中加一段判断的逻辑 ...

  9. Struts2框架学习(二)——访问流程及架构

    1.Struts2的执行流程 从客户端发送请求过来,先经过前端控制器(核心过滤器StrutsPrepareAndExecuteFilter)过滤器中执行一组拦截器(一组拦截器就会完成部分功能代码),拦 ...

  10. 2-SAT 小结

    PS:今天(2014.10.27)准备PPT,明天在组合数学课上与大家一起分享一下2-SAT.我以为是一件简单的事情.但是,当我看了自己这篇博客以后,发现居然还是不懂.很多资料不全,也没仔细讲.整理了 ...