OC学习 第七节 手动内存管理

2024-02-26 08:08

本文主要是介绍OC学习 第七节 手动内存管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

回顾
malloc free
JAVA C# GC Garbage collection 垃圾回收机制
mac os
ARC Automatic Reference Count 自动引用计数
MRC Manual Reference Count 手动管理内存

引用计数
引用:强引用/弱引用
弱引用:assign
引用计数


# 手动内存管理(Manual Reference Counting)(应用非常灵活)MRC
ARC (Automatic Reference Counting)

堆空间 :
         1.忘记释放  —> 内存泄露
         2.提前/过早释放 ---> 内存崩溃
         3.多释放  —> 崩溃 C野指针

malloc free free

         内存管理 管理的是堆空间
         谁来释放?程序员负责释放

# 内存管理原理
# c模拟
# retain release dealloc
# new
# setter方法中的内存注意事项
# 不要管太多,管好自己 黄金法则
#import <Foundation/Foundation.h>

int main(int argc, const char * argv[]) {
    NSMutableString *str1 = nil;
    NSMutableString *str2 = nil;
    @autoreleasepool {
        str1 = [[NSMutableString alloc] initWithString:@"Welcome to beijing"];
        str2 = [NSMutableString stringWithString:@"Welcome to zhenzhou"];
        NSLog(@"%@ %ld", str1, str1.retainCount);
        NSLog(@"%@ %ld", str2, str2.retainCount);
    }
    
    NSLog(@"-------------------------");
    
    [str1 setString:@"Respect China"];
    [str1 release];
    [str1 release];
    NSLog(@"%@ %ld", str1, str1.retainCount);
    //[str2 release];
    //NSLog(@"%@ %ld", str2, str2.retainCount);
    return 0;
}

    /*
     综上,上面的内存管理比较混乱,有些对象创建之后 用完了可以release释放,有些创建对象之后 就不能再次release
     
     如何解决上面的混乱??
     要遵守OC内存管理原则/法则 ----》黄金法则
     //alloc/new  copy /mutableCopy 会使对象计数器置为1
     //retain 使对象的计数器+1
     
     当我们程序员自己用alloc/new/copy/mutableCopy/retain开头的函数把对象地址赋给一个新的指针变量(拥有了对象的绝对使用权),指针用完对象之后,不再使用对象的时候,那么指针应该立即release或者autorelease(放弃绝对使用权)。每个指针只需要管理好自己就可以了,不需要管理其他的指针(各人顾个人原则),释放之后的指针就不要再操作原来的对象了
     
     
     结论
     1.只有程序员自己写出来alloc/new/copy/mutableCopy/retain这些函数,用完指针之后要对应出现一个release/autorelease
       如果没有上面的函数 就不需要管
     
     2.什么时候retain???  当一个对象多出一个指针指向的时候
     
     以后我们在写代码的时候 都要遵守黄金法则
     */

# 字符串的copy/mutableCopy
注:
Dog *dog2 = [dog1 copy];
在使用copy /mutableCopy的时候 ,使用的对象所属的类必须要遵守协议NSCopying /NSMutableCopying协议,实现里面的方法。
因为在执行copy函数的时候,内部会调用当前对象的copyWithZone:方法, 所以使用copy前 必须要遵守协议实现copyWithZone:方法

NSString NSArray NSDictionary 这些类都遵守了拷贝协议 实现了里面的方法,可以直接用copy 。可以字符串对象常常用拷贝函数


# dealloc
# 内存管理之属性要注意的地方
# autorelease和自动释放池
# 数组/字典的内存管理

这篇关于OC学习 第七节 手动内存管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/748184

相关文章

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

nvm如何切换与管理node版本

《nvm如何切换与管理node版本》:本文主要介绍nvm如何切换与管理node版本问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录nvm切换与管理node版本nvm安装nvm常用命令总结nvm切换与管理node版本nvm适用于多项目同时开发,然后项目适配no

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Redis实现RBAC权限管理

《Redis实现RBAC权限管理》本文主要介绍了Redis实现RBAC权限管理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1. 什么是 RBAC?2. 为什么使用 Redis 实现 RBAC?3. 设计 RBAC 数据结构

Redis 内存淘汰策略深度解析(最新推荐)

《Redis内存淘汰策略深度解析(最新推荐)》本文详细探讨了Redis的内存淘汰策略、实现原理、适用场景及最佳实践,介绍了八种内存淘汰策略,包括noeviction、LRU、LFU、TTL、Rand... 目录一、 内存淘汰策略概述二、内存淘汰策略详解2.1 ​noeviction(不淘汰)​2.2 ​LR

Golang基于内存的键值存储缓存库go-cache

《Golang基于内存的键值存储缓存库go-cache》go-cache是一个内存中的key:valuestore/cache库,适用于单机应用程序,本文主要介绍了Golang基于内存的键值存储缓存库... 目录文档安装方法示例1示例2使用注意点优点缺点go-cache 和 Redis 缓存对比1)功能特性

Go使用pprof进行CPU,内存和阻塞情况分析

《Go使用pprof进行CPU,内存和阻塞情况分析》Go语言提供了强大的pprof工具,用于分析CPU、内存、Goroutine阻塞等性能问题,帮助开发者优化程序,提高运行效率,下面我们就来深入了解下... 目录1. pprof 介绍2. 快速上手:启用 pprof3. CPU Profiling:分析 C

mac安装nvm(node.js)多版本管理实践步骤

《mac安装nvm(node.js)多版本管理实践步骤》:本文主要介绍mac安装nvm(node.js)多版本管理的相关资料,NVM是一个用于管理多个Node.js版本的命令行工具,它允许开发者在... 目录NVM功能简介MAC安装实践一、下载nvm二、安装nvm三、安装node.js总结NVM功能简介N

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2