ARC-MRC下的单例宏

2024-05-16 00:58
文章标签 单例 arc mrc

本文主要是介绍ARC-MRC下的单例宏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://my.oschina.net/panyong/blog/302502

  • define SingletonH(methodName) + (instancetype)shared##methodName;
  • if __has_feature(objc_arc) // 是ARC
  • define SingletonM(methodName) \
  • else // 不是ARC
  • define SingletonM(methodName) \
  • endif

先别急,先简单提一下单列的概念,当然具体的描述可能仁者见仁智者见智了! 
1.单例设计模式(Singleton) 
1> 什么是单列: 它可以保证某个类创建出来的对象永远只有1个

2> 作用(为什么要用)

  • 节省内存开销
  • 如果有一些数据, 整个程序中都用得上, 只需要使用同一份资源(保证大家访问的数据是相同的,一致的)
  • 一般来说, 工具类设计为单例模式比较合适

3> 怎么实现,老程序员是碰到这样的问题的!arc下就少了!

  • MRC(非ARC)
  • ARC

废话少说,先来看一下我的单例模式下的头文件! 这里主要是__has_feature(objc_arc) 判断了一下是否为arc,所以代码看上去有点多!

?
1
// 帮助实现单例设计模式

// .h文件的实现

define SingletonH(methodName) + (instancetype)shared##methodName;

// .m文件的实现

if __has_feature(objc_arc) // 是ARC

define SingletonM(methodName) \

static id _instace = nil; \

  • (id)allocWithZone:(struct NSZone *)zone \ 
    { \ 
    if (
    instace == nil) { \ 
    static dispatch_once_t onceToken; \ 
    dispatch_once(&onceToken, ^{ \ 
    instace = [super allocWithZone:zone]; \ 
    }); \ 
    } \ 
    return 
    instace; \ 
    } \ 
    \
  • (id)init \ 
    { \ 
    static dispatch_once_t onceToken; \ 
    dispatch_once(&onceToken, ^{ \ 
    instace = [super init]; \ 
    }); \ 
    return 
    instace; \ 
    } \ 
    \
  • (instancetype)shared##methodName \ 
    { \ 
    return [[self alloc] init]; \ 
    } \
  • (id)copyWithZone:(struct NSZone *)zone \ 
    { \ 
    return 
    instace; \ 
    } \ 
    \
  • (id)mutableCopyWithZone:(struct NSZone *)zone \ 
    { \ 
    return 
    instace; \ 
    }

else // 不是ARC

define SingletonM(methodName) \

static id _instace = nil; \

  • (id)allocWithZone:(struct NSZone *)zone \ 
    { \ 
    if (
    instace == nil) { \ 
    static dispatch_once_t onceToken; \ 
    dispatch_once(&onceToken, ^{ \ 
    instace = [super allocWithZone:zone]; \ 
    }); \ 
    } \ 
    return 
    instace; \ 
    } \ 
    \
  • (id)init \ 
    { \ 
    static dispatch_once_t onceToken; \ 
    dispatch_once(&onceToken, ^{ \ 
    instace = [super init]; \ 
    }); \ 
    return 
    instace; \ 
    } \ 
    \
  • (instancetype)shared##methodName \ 
    { \ 
    return [[self alloc] init]; \ 
    } \ 
    \
  • (oneway void)release \ 
    { \ 

    } \ 
    \
  • (id)retain \ 
    { \ 
    return self; \ 
    } \ 
    \
  • (NSUInteger)retainCount \ 
    { \ 
    return 1; \ 
    } \
  • (id)copyWithZone:(struct NSZone *)zone \ 
    { \ 
    return 
    instace; \ 
    } \ 
    \
  • (id)mutableCopyWithZone:(struct NSZone *)zone \ 
    { \ 
    return 
    instace; \ 
    }

endif

这个里面完完全全的做到了,单列所有情况的考虑,包括copy情况,多线程,还有自动判断ARC和MRC情况! 
用的时候只需要在包含头文件然后是用下面 
.h文件下:SingletonH(HttpTool) 
.m文件下:SingletonM(HttpTool)

这东西谁用谁知道!!!!嘻嘻!希望对读者有帮助!


这篇关于ARC-MRC下的单例宏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

使用Spring Boot集成Spring Data JPA和单例模式构建库存管理系统

引言 在企业级应用开发中,数据库操作是非常重要的一环。Spring Data JPA提供了一种简化的方式来进行数据库交互,它使得开发者无需编写复杂的JPA代码就可以完成常见的CRUD操作。此外,设计模式如单例模式可以帮助我们更好地管理和控制对象的创建过程,从而提高系统的性能和可维护性。本文将展示如何结合Spring Boot、Spring Data JPA以及单例模式来构建一个基本的库存管理系统

C#设计模式(1)——单例模式(讲解非常清楚)

一、引言 最近在学设计模式的一些内容,主要的参考书籍是《Head First 设计模式》,同时在学习过程中也查看了很多博客园中关于设计模式的一些文章的,在这里记录下我的一些学习笔记,一是为了帮助我更深入地理解设计模式,二同时可以给一些初学设计模式的朋友一些参考。首先我介绍的是设计模式中比较简单的一个模式——单例模式(因为这里只牵涉到一个类) 二、单例模式的介绍 说到单例模式,大家第一

单例模式以及反射对单例模式的破坏及防御

单例模式(Singleton Pattern)是一种确保类在应用程序生命周期内只存在一个实例的设计模式。它不仅提供了全局访问点,还能节省内存、控制实例的生命周期。但常见的单例模式实现方式如饿汉式、懒汉式、双重校验锁、静态内部类等,虽然设计良好,但都容易被 Java 的反射机制所破坏。本文将介绍这些单例实现方式的优缺点、反射如何破坏它们的唯一性,以及如何防御这种破坏。 1. 单例模式的常见实现

线程--(1)单例模式创建

通过内部类创建单例模式 package com.flx.king.it_201707;/*** 公共:单例模式与多线程实现* * @author FuLX* @2017-7-26下午10:14:08* */public class Dome_02_SingletonAndManyThread {//1、定义一个内部类private static class Singletion{//创建单

1 单例模式(设计模式笔记)

1 单例模式 概述:使得一个类的对象成为系统中的唯一实例。 具体实现: 构造函数私有化 限制实例的个数 懒汉式(时间换空间) public class Singleton2 {public static Singleton2 singleton2;private Singleton2(){}public static Singleton2 getInstance() throws I

设计模式(2)-- 单例模式

单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建。这个类提供了一种访问其唯一的对象的方式,可以直接访问,不需要实例化该类的对象。 注意: 1、单例类只能有一个实例。 2、单例类必须自己创建自己的唯一实例。 3、单

C++ | 单例设计模式(懒汉式单例模式源码|饿汉式单例模式)

点击上方"蓝字"关注我们 01、概念 >>> 单例设计模式(Singleton Pattern)是一种创建型设计模式,确保一个类只有一个实例,并提供一个全局访问点来访问该实例。单例模式通常用于需要在整个应用程序中共享一个对象的场景,例如配置管理、日志记录、数据库连接池等。 02、场景 >>> 应用场景 配置管理:应用程序的配置信息通常只需要一个实例来管理,避免多个配置实例导致数据不

使用 `readResolve` 防止序列化破坏单例模式

单例模式是一种设计模式,其目的是确保一个类只有一个实例,并提供一个全局访问点。在 Java 中,我们常常通过私有化构造方法和提供静态访问方法来实现单例。然而,尽管这些手段可以有效防止类的实例化,反射和序列化依然能够破坏单例模式的唯一性。本文将重点讲解序列化如何破坏单例模式,以及如何通过 readResolve 方法来防止这种破坏。 1. 序列化和反序列化 序列化 是指将对象的状态转换为字节

python单例模式练习

单例设计模式是怎么来的? 单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在。当你希望在整个系统中,某个类只能出现一个实例时,单例对象就能派上用场。 在面向对象的程序设计中,当业务并发量非常大时,那么就会出现重复创建相同的对象,每创建一个对象就会开辟一块内存空间,而这些对象其实是一模一样的,那么有没有办法使用得内存对象只创建一