IOS ARC和GCD结合的单例模式

本文介绍了一种在iOS开发中实现单例模式的方法,利用GCD的dispatch_once特性确保单例对象仅初始化一次,并提供了宏定义简化单例类的创建过程。

单例模式在iOS开发过程中经常用到,苹果提供过objective c单例的比较官方的写法:

  1. static MyGizmoClass *sharedGizmoManager = nil;  
  2.    
  3. + (MyGizmoClass*)sharedManager  
  4. {  
  5.     @synchronized(self) {  
  6.         if (sharedGizmoManager == nil) {  
  7.             [[self alloc] init]; // assignment not done here  
  8.         }  
  9.     }  
  10.     return sharedGizmoManager;  
  11. }  
  12.    
  13. + (id)allocWithZone:(NSZone *)zone  
  14. {  
  15.     @synchronized(self) {  
  16.         if (sharedGizmoManager == nil) {  
  17.             sharedGizmoManager = [super allocWithZone:zone];  
  18.             return sharedGizmoManager;  // assignment and return on first allocation  
  19.         }  
  20.     }  
  21.     return nil; //on subsequent allocation attempts return nil  
  22. }  
  23.    
  24. - (id)copyWithZone:(NSZone *)zone  
  25. {  
  26.     return self;  
  27. }  
  28.    
  29. - (id)retain  
  30. {  
  31.     return self;  
  32. }  
  33.    
  34. - (unsigned)retainCount  
  35. {  
  36.     return UINT_MAX;  //denotes an object that cannot be released  
  37. }  
  38.    
  39. - (void)release  
  40. {  
  41.     //do nothing  
  42. }  
  43.    
  44. - (id)autorelease  
  45. {  
  46.     return self;  
  47. }  

现在iOS5之后普遍使用了ARC技术,原来这个写法就显得很累赘了,release已经不使用了。

咱们可以结合GCD来实现单例模式:

  1. + (id)sharedInstance  
  2. {  
  3.   static dispatch_once_t pred = 0;  
  4.   __strong static id _sharedObject = nil;  
  5.   dispatch_once(&pred, ^{  
  6.     _sharedObject = [[self alloc] init]; // or some other init method  
  7.   });  
  8.   return _sharedObject;  
  9. }  
使用dispatch_once,这个方法的意思是在应用程序生命周期内,这方法只执行一次,这就是ARC下结合GCD的一个单例的代码

因为我们可能需要多个单例的类,每个都写一次比较麻烦,可以更方便一些,把这些代码写成宏的形式,只需要传入类名就可以创建一个单例的类了。

通过传入类名创建头文件中单例方法的名称:

  1. #define DEFINE_SINGLETON_FOR_HEADER(className) \  
  2. \  
  3. + (className *)shared##className;  


通过传入类名创建单例方法的实现
  1. #define DEFINE_SINGLETON_FOR_CLASS(className) \  
  2. \  
  3. + (className *)shared##className { \  
  4. static className *shared##className = nil; \  
  5. static dispatch_once_t onceToken; \  
  6. dispatch_once(&onceToken, ^{ \  
  7. shared##className = [[self alloc] init]; \  
  8. }); \  
  9. return shared##className; \  
  10. }  

使用宏:

在项目中新建了一个类testSingleton,并且有.h 和.m文件。

.h

.m中的代码:

  1. #import "testSingleton.h"  
  2.   
  3. @implementation testSingleton  
  4. DEFINE_SINGLETON_FOR_CLASS(testSingleton)  
  5. @end  

  1. #define DEFINE_SINGLETON_FOR_HEADER(className) \  
  2. \  
  3. + (className *)shared##className;  
  4.   
  5. #define DEFINE_SINGLETON_FOR_CLASS(className) \  
  6. \  
  7. + (className *)shared##className { \  
  8. static className *shared##className = nil; \  
  9. static dispatch_once_t onceToken; \  
  10. dispatch_once(&onceToken, ^{ \  
  11. shared##className = [[self alloc] init]; \  
  12. }); \  
  13. return shared##className; \  
  14. }  
  15.   
  16. #import <Foundation/Foundation.h>  
  17.   
  18. @interface testSingleton : NSObject  
  19. DEFINE_SINGLETON_FOR_HEADER(testSingleton);  
  20. @end  
你可以把宏单独放到项目管理宏的文件中。这里是为了方便演示放到和testSingleton.h文件了。
获取单例:
  1. - (void)test  
  2. {  
  3.     testSingleton *testShare = [testSingleton sharedtestSingleton];  
  4. }  

有什么不明白的可以留言交流。

源码来自:https://pan.quark.cn/s/a3a3fbe70177 AppBrowser(Application属性查看器,不需要越狱! ! ! ) 不需要越狱,调用私有方法 --- 获取完整的已安装应用列表、打开删除应用操作、应用运行时相关信息的查看。 支持iOS10.X 注意 目前AppBrowser不支持iOS11应用查看, 由于iOS11目前还处在Beta版, 系统API还没有稳定下来。 等到Private Header更新了iOS11版本,我也会进行更新。 功能 [x] 已安装的应用列表 [x] 应用的详情界面 (打开应用,删除应用,应用的相关信息展示) [x] 应用运行时信息展示(LSApplicationProxy) [ ] 定制喜欢的字段,展示在应用详情界面 介绍 所有已安装应用列表(应用icon+应用名) 为了提供思路,这里只用伪代码,具体的私有代码调用查看: 获取应用实例: 获取应用名应用的icon: 应用列表界面展示: 应用列表 应用运行时详情 打开应用: 卸载应用: 获取info.plist文件: 应用运行时详情界面展示: 应用运行时详情 右上角,从左往右第一个按钮用来打开应用;第二个按钮用来卸载这个应用 INFO按钮用来解析并显示出对应的LSApplicationProxy类 树形展示LSApplicationProxy类 通过算法,将LSApplicationProxy类,转换成了字典。 转换规则是:属性名为key,属性值为value,如果value是一个可解析的类(除了NSString,NSNumber...等等)或者是个数组或字典,则继续递归解析。 并且会找到superClass的属性并解析,superClass如...
基于遗传算法辅助异构改进的动态多群粒子群优化算法(GA-HIDMSPSO)的LSTM分类预测研究(Matlab代码实现)内容概要:本文研究了一种基于遗传算法辅助异构改进的动态多群粒子群优化算法(GA-HIDMSPSO),并将其应用于LSTM神经网络的分类预测中,通过Matlab代码实现。该方法结合遗传算法的全局搜索能力与改进的多群粒子群算法的局部优化特性,提升LSTM模型在分类任务中的性能表现,尤其适用于复杂非线性系统的预测问题。文中详细阐述了算法的设计思路、优化机制及在LSTM参数优化中的具体应用,并提供了可复现的Matlab代码,属于SCI级别研究成果的复现与拓展。; 适合人群:具备一定机器学习优化算法基础,熟悉Matlab编程,从事智能算法、时间序列预测或分类模型研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①提升LSTM在分类任务中的准确性与收敛速度;②研究混合智能优化算法(如GA与PSO结合)在神经网络超参数优化中的应用;③实现高精度分类预测模型,适用于电力系统故障诊断、电池健康状态识别等领域; 阅读建议:建议读者结合Matlab代码逐步调试运行,理解GA-HIDMSPSO算法的实现细节,重点关注种群划分、异构策略设计及与LSTM的集成方式,同时可扩展至其他深度学习模型的参数优化任务中进行对比实验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值