作者:ID张蕾 | 来源:互联网 | 2023-08-14 10:51
1.前言
因为公司有个国外餐饮系统,编程开发了3-4年,之前用的都是非ARC,开发到今年,第一批迭代开发的人员早已不见,目前发现了有许多的内存泄露之类的,系统没有自动释放该释放的内存。一旦app长时间使用,内存没有得到释放,最后导致app闪崩。涉及到的地方特别多,特别繁杂。故我有了打算将此项目完全转换称arc项目的意向。经过1个星期的转换与1个星期的测试,成功将非arc项目转换称arc项目。
因为很少找到有公司将大型老app进行arc转换,所以网上这方面的资料都特别少。
经过这次尝试,我证明了是可行的。
现在就在博客里总结一下我遇到的一些问题。
毕竟ARC是objc未来。
Xcode 自带一个自动转换的功能,不过只适合比较小的项目,在大型项目上是不适合适用的,所以我这里是全手动转换。
2.将项目编译环境改成arc
将红圈处从No 改成Yes
如果你现在的工程不支持ARC技术,你可以通过一个自动转换工具来转换你的工程(工具在Edit>Refactor>Convertto Objective-C ARC),这个工具会自动所有工程中手动管理内存的点转换成合适自动方式的(比如移除retain, release等)。这个工具会转换工程中所有的文件。当然你可以转换单个文件。
3.下面的这些函数:dealloc,retain, release, retainCount, autorelease。禁止任何形式调用和实现(dealloc可能会被实现)
将这些内存管理的东西全部删掉或注释
4.不能使用NSAutoreleasePool.可以考虑直接注释
作为替代,@autoreleasepool被引入,你可以使用这个效率更高的关键词。
5.在做桥接转换时报错,用xcode提示替换
6.ARC语法的一些规则
6.1.代码中不能使用retain, release, retain, autorelease
6.2.不重载dealloc(如果是释放对象内存以外的处理,是可以重载该函数的,但是不能调用[super dealloc])
6.3.不能使用NSAllocateObject, NSDeallocateObject
6.4.不能在C结构体中使用对象指针
6.5.id与void *间的如果cast时需要用特定的方法(__bridge关键字)
6.6.不能使用NSAutoReleasePool、而需要@autoreleasepool块
6.7.不能使用“new”开始的属性名称 (如果使用会有下面的编译错误”Property’s synthesized getter follows Cocoa naming convention for returning ‘owned’ objects”)
7.第三方包的问题,第三方框架的问题
我们项目里可能引用了许多第三方框架。
大部分都是用一些宏来让代码可以同时适应arc和非arc的(用#if __has_feature(objc_arc)判断)。如果代码量不大,可以考虑自己进行改写
你可以按上面的步骤将第三方框架自己手动改称arc
如果是大型框架的话,可以采取标记此框架保留非arc的环境不变,继续使用。
1,选择项目中的Targets,选中你所要操作的Target,
2,选Build Phases,在其中Complie Sources中选择需要ARC的文件双击,并在输入框中输入:-fobjc-arc,如果不要ARC则输入:-fno-objc-arc