OC_简单的单例模式笔记

1 单例模式概念

单例模式: 单例模式的意图是类的对象称为系统中唯一的实例,提供一个访问点,拱客户类共享资源

   类只能有一个实例,而且必须从一个为人熟知的访问点对其进行访问,比如工厂方法。
           这个唯一的实例只能通过子类进行扩展,而且扩展的对象不会破坏客户端代码
要点:
(1) 某个类只能有一个实例。
(2)他必须自行创建这个对象
(3)必须自行向整个系统提供这个实例;
(4)为了保证实例的唯一性,我们必须将
-(id)copyWithZone:(NSZone*)zone
+(id)allocWithZone:(NSZone*)zone
-(id)retain
-(NSUInteger)retainCount
-(onewayvoid)release
-(id)autorelease 的实现方法进行覆盖。
(5)这个方法必须是一个静态类

2 单例模式实现


Tools.h
#import <Foundation/Foundation.h>
@interfaceTools : NSObject<NSCopying>
@property(nonatomic,assign) intnum;
@property(nonatomic,copy) NSString*text;
+(instancetype)shareIntances;
@end
Tools.m
staticTools*instance = nil;
@implementationTools
+(instancetype)shareIntances{
if(instance==nil) {
instance= [[selfallocWithZone:NULL] init];
}
returninstance;
}
-(id)copyWithZone:(NSZone*)zone{
returnself;
}
+(id)allocWithZone:(NSZone*)zone{
@synchronized(self) {
if(instance== nil) {
instance= [superallocWithZone:zone];
returninstance;
}
}
returninstance;
}
-(id)retain{
returnself;
}
-(NSUInteger)retainCount{
#import "Tools.h"
returnNSUIntegerMax;
}
-(onewayvoid)release{
}
-(id)autorelease{
returnself;
}
@end

注意:所谓单例,即我们自己创建一个单例类,该类只能生成唯一的对象,即用if(sharesingleton==nil) 方法来保证唯一性,为了防止该对象被复制(copy)或者retain 和release 等操作,我们必须在所创建的单例的实现文件(.m 文件)中将父类的这些方法给覆盖,该目的是为了保证单例模式的一个严谨性。
我的代码是这样的void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin) { if(GPIO_Pin == TCA9555OC_INT_Pin) //TCA9555的过流信号变化中断 { uint16_t OC_EventBits = 0;//初始化过流事件组的置位位 static uint8_t pause_command[9]={0x01,0x09,0x01,0x00,0x04,0x0D,0x00,0x00,0x1C};//初始化暂停指令 //先读取TCA9555的输入引脚状态 uint16_t TCA9555OC_GPIOINPUT = TCA9555_ReadPortInPutStatus(TCA9555_IIC_HANDLE,TCA9555_OC_Address); //再根据过流信号的状态,将对应的过流事件位置1 if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH1) OC_EventBits |= OverCurrent_Status_CH1; if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH2) OC_EventBits |= OverCurrent_Status_CH2; if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH3) OC_EventBits |= OverCurrent_Status_CH3; if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH4) OC_EventBits |= OverCurrent_Status_CH4; if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH5) OC_EventBits |= OverCurrent_Status_CH5; if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH6) OC_EventBits |= OverCurrent_Status_CH6; if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH7) OC_EventBits |= OverCurrent_Status_CH7; if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH8) OC_EventBits |= OverCurrent_Status_CH8; if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH9) OC_EventBits |= OverCurrent_Status_CH9; if(TCA9555OC_GPIOINPUT & TCA9555_OC_CH10) OC_EventBits |= OverCurrent_Status_CH10; //全部过流信号取反 OC_EventBits = ~OC_EventBits; //最后把总过流位置1 OC_EventBits |= OverCurrent_Status_All; //将过流事件组的置位位设置到过流事件组中,使用ISR安全操作模式 xEventGroupSetBitsFromISR(OverCurrent_Status_Flags_EventHandle,OC_EventBits, pdFALSE); //全部通道断电 Close_AllChannel_PowerSupply(); //进行暂停 HAL_GPIO_WritePin(PAUSE_LED_32_GPIO_Port,PAUSE_LED_32_Pin,GPIO_PIN_SET);//打开暂停指示灯 Command_SendtoHMI(pause_command,&HMI_UART);//发送暂停指令给HMI osEventFlagsClear(ManageChannel_Test_Flags_EventHandle, Channel_Continue_Flag);//将管理事件组的继续位清0 } }
最新发布
04-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值