08.内存管理

手动内存管理
什么是内存管理

.进程空间
-代码区:只读
 -堆:自己创建、自己回收释放,对象是保存在堆区的。
-全局区:进程启动时候分配,进行结束时释放。
-栈:局部变量,自动创建,自动释放空间
.什么是内存管理
-只要对堆内进行管理,所谓的管理是值内存的分配(创建)和释放(回收).

引用计算器为1(alloc,copy,new)
.引用计算器为1(alloc,copy,new)
-每个对象都有自己的引用计数器,引用计算器是用来计算对象被引用的次数
-发送消息时(alloc,copy,new),将引用计数器置1。

assign关键字
-retain如果属性是对象,就会使用此关键字,解决内存问题
-asssign如果属性是基本数据类型,默认’就是assign,不会解决内存问题。
-copy一些特殊对象类型,如果不希望和比人共享一个对象用copy会自动创建一个新的对象。
-readonly 只读,去掉setter,只保留getter
-weak,用于一些基本控件

引用计数器加1(retain)
.引用计数器加1(retain)
当你需要使用一个别人创建好的对象时,为了防止在使用此对象期间别人释放了这个对象,我们要将此对象的引用计算器加1(程序员通知引用计数器),只要给对象发送retain消息,引用计数器就会加1.

引用计数器减1(release)
引用计数器减1(release)
-当你使用的对象不在使用的时候,就发送release消息
-release消息将对象的引用计数器减1
-如果引用计数器为0,则释放对象所占的存储空间

dealloc与对象销毁
.dealloc与对象销毁
-当对象的引用计数器为0时,说明已经没有任何引用指向对象,对象就会被系统自动销毁
-系统销毁对象之前,会自动向对象发送一条消息“dealloc”消息,对象所占的空间就会被释放,千万不要自己去调用dealloc消息
.可以使用“retainCount消息“,查看当前引用计数器的值。

.野指针与空指针
.野指针与空指针
-当你指向的对象,不在使用时,如果忘了发送release消息,内存泄露(资源浪费)
-当引用指向的对象已经不存在了,继续向对象发送消息,会发生问题,如异常,crash
-没有相应内存空间的指针,野指针
-会使用空指针,解决指针问题,而在oc中,向空指针发送消息,是不会报错的stu = nil;

声明式属性与内存管理
.声明式属性与内存管理
-注意:声明属性默认情况下,并没有解决内存问题
-当使用@property(retain)引用数据类型,帮我们解决了setter使用中内存问题,但dealloc中的release操作,还是需要我们自己来做的。

atomic与nonatomic
.atomic与nonatomic
-nonatomic非原子性操作,安全性低,效率高。
-atomic 原子性操作,在多线程使用的时候,一般是用来防止写未完成的时候,被另一个线程读取,造成数据安全性问题,这种操作消耗资源的。

自动释放池
什么是自动释放池
通过释放池来管理对象,只需要一个自动释放池,可以管理很多对象,但自动释放池结束的时候,会自动向池中的每个对象发送release消息

时间: 2024-10-17 08:26:04

08.内存管理的相关文章

[objective-c] 08 - 内存管理

OC语言中的内存管理机制为ARC(Automatic Reference Counting,自动引用计数).与2011年中旬推出,替换陈旧且低效的手动内存管理,关于手动内存管理的内容,本章教程不在讲授.本章主要从以下几个方面对内存管理进行展开讲讲解. 内存管理原则 对象引用类型 属性引用类型 强引用循环 AUTO类型与释放池 1.内存管理原则 核心原则:没有被对象指针使用(指向)的内存立即释放.这个原则决定一般情况下,不会用内存泄露的情况存在,但存在特殊情况,也是本章最后一个专题要阐述的问题.

(转)从内存管 理、内存泄漏、内存回收探讨C++内存管理

http://www.cr173.com/html/18898_all.html 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题,C++高手从中获得了更好的性能,更大的自由,C++菜鸟的收获则是一遍一遍的检查代码和对 C++的痛恨,但内存管理在C++中无处不在,内存泄漏几乎在每个C++程序中都会发生,因此要想成为C++高手,内存管理一关是必须要过的,除非放弃 C++,转到Java或者.NET,他们的内存管理基本是自动的,当然你也放弃了自由和对内存的支配权,还放弃了C++超绝的性能

设置ORACLE自动内存管理

文章参考:ORACLE 11g官方文档[Managing Memory] 前言:之前搭建数据库集群环境后,现场的维护人员不知何时改为了手动内存管理,且参数设置存在不合理,导致客户plsql执行报错,如下所示: 查看数据库日志,有如下提示: Wed Mar 15 00:15:08 2017 Errors in file /app/oracle/diag/rdbms/resdb/resdb1/trace/resdb1_ora_12320832.trc  (incident=441054): ORA-

C++内存管理(超长,例子很详细,排版很好)

[导语] 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题,C++高手从中获得了更好的性能,更大的自由,C++菜鸟的收获则是一遍一遍的检查代码和对C++的痛恨,但内存管理在C++中无处不在,内存泄漏几乎在每个C++程序中都会发生,因此要想成为C++高手,内存管理一关是必须要过的,除非放弃C++,转到Java或者.NET,他们的内存管理基本是自动的,当然你也放弃了自由和对内存的支配权,还放弃了C++超绝的性能.本期专题将从内存管理.内存泄漏.内存回收这三个方面来探讨C++内存管理问题

C++内存管理(超长)

[导语] 内存管理是C++最令人切齿痛恨的问题,也是C++最有争议的问题,C++高手从中获得了更好的性能,更大的自由,C++菜鸟的收获则是一遍一遍的检查代码和对C++的痛恨,但内存管理在C++中无处不在,内存泄漏几乎在每个C++程序中都会发生,因此要想成为C++高手,内存管理一关是必须要过的,除非放弃C++,转到Java或者.NET,他们的内存管理基本是自动的,当然你也放弃了自由和对内存的支配权,还放弃了C++超绝的性能.本期专题将从内存管理.内存泄漏.内存回收这三个方面来探讨C++内存管理问题

NSString初始化及其内存管理

1. NSString 3种初始化方法 a. 直接赋值: NSString *str = @"a string", 这种方式使用常量内存. b. 使用类方法: NSString *str = [NSString stringWithString:@"a string"];    NSString * str = [NSString stringWithFormat:@"age is %i, height is %f", 20, 180]; c.

Oracle内存管理(之五)

[深入解析--eygle]学习笔记 1.4. 2其他内存组件 Large Pool-大池是SGA的一个可选组件,通常用于共享服务器模式(MTS). 并行计算或 RMAN的备份恢复等操作. Java Pool-Java池主要用于JVM等Java选件. Streams Pool-Streams pool是Oracle10g引入的概念,为Oracle的Streams功能所使用,如果不定义该参数,这部分内存将从Shread Pool中分配 对于SGA各部分内存分配,可以从数据库的视图中查询得到: 17:

C++内存管理机制(持续更新中......)

C++内存管理: 名称 分配 栈区 函数内部局部变量的存储单元在栈区,函数执行结束时,这些存储单元被释放.效率高,但是分配的内存容量有限. 堆区 就是那些由new分配的内存块,他们的释放编译器不去管,由我们的应用程序去控制,一般一个new就要对应一个delete.如果程序员没有释放掉,那么在程序结束后,操作系统会自动回收. 自由存储区 就是那些由malloc等分配的内存块,他和堆是十分相似的,不过它是用free来结束自己的生命的. 全局/静态存储区 全局变量和静态变量被分配到同一块内存中,在以前

NETTY4中的BYTEBUF 内存管理

转 http://iteches.com/archives/65193 Netty4带来一个与众不同的特点是其ByteBuf的重现实现,老实说,java.nio.ByteBuf是我用得很不爽的一个API,相比之下,通过维护两个独立的读写指针,io.netty.buffer.ByteBuf要简单不少,也会更高效一些.不过,Netty的ByteBuf带给我们的最大不同,就是他不再基于传统JVM的GC模式,相反,它采用了类似于C++中的malloc/free的机制,需要开发人员来手动管理回收与释放.从