iOS开发篇 - 单例设计模式(下)

简介: 所谓单例就是确保在程序运行过程中只创建一个对象实例,可以用于需要被多次广泛或者说多次使用的资源中,比如我们常见的网络请求类、工具类、以及其他管理类。在iOS开发中,单例模式是非常有用的设计模式

测试


一.  对假单例进行调用


单例写法

//  Singleton.m
//  TestSingleton
//
//  Created by taobaichi on 2017/4/13.
//  Copyright © 2017年 MaChao. All rights reserved.
//
#import "Singleton.h"
static Singleton * _sharedSingleton = nil;
@implementation Singleton
+(Singleton *)sharedInstance
{
    if (_sharedSingleton == nil) {
        _sharedSingleton = [[Singleton alloc]init];
    }
    return _sharedSingleton;
}
@end


  • 调用方法一

//
//  ViewController.m
//  TestSingleton
//
//  Created by taobaichi on 2017/4/13.
//  Copyright © 2017年 MaChao. All rights reserved.
//
#import "ViewController.h"
#import "Singleton.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad {
    [super viewDidLoad];
    [self testSingleton];
}
-(void)testSingleton
{
    Singleton * single1 = [Singleton sharedInstance];
    Singleton * single2 = [Singleton sharedInstance];
    if (single1 == single2) {
        NSLog(@"single1 == single2");
    }
    NSLog(@"single1地址   %@",single1);
    NSLog(@"single2地址   %@",single2);
}
- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}
@end


打印结果

2017-04-13 13:12:27.327 TestSingleton[2515:106202] single1 == single2
2017-04-13 13:12:27.327 TestSingleton[2515:106202] single1地址   <Singleton: 0x6000000147f0>
2017-04-13 13:12:27.327 TestSingleton[2515:106202] single2地址   <Singleton: 0x6000000147f0>


  • 调用方法二:

//
//  ViewController.m
//  TestSingleton
//
//  Created by taobaichi on 2017/4/13.
//  Copyright © 2017年 MaChao. All rights reserved.
//
#import "ViewController.h"
#import "Singleton.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad {
    [super viewDidLoad];
    [self testSingleton];
}
-(void)testSingleton
{
    Singleton * single1 = [[Singleton alloc]init];
    Singleton * single2 = [[Singleton alloc]init];
    if (single1 == single2) {
        NSLog(@"single1 == single2");
    }
    NSLog(@"single1地址   %@",single1);
    NSLog(@"single2地址   %@",single2);
}
- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}
@end


打印结果:

2017-04-13 13:13:47.526 TestSingleton[2529:108124] single1地址   <Singleton: 0x60800001cda0>
2017-04-13 13:13:47.526 TestSingleton[2529:108124] single2地址   <Singleton: 0x60800001cdb0>


可以看到,假单例当用alloc实例化的时候,生成的并不是一个单例,也就是说并不是同一个对象


二. 对真单例无论怎么实例化生成的都是同一个对象


真单例写法

//
//  Singleton.m
//  TestSingleton
//
//  Created by taobaichi on 2017/4/13.
//  Copyright © 2017年 MaChao. All rights reserved.
//
#import "Singleton.h"
static Singleton * _sharedSingleton = nil;
@implementation Singleton
+(instancetype)allocWithZone:(struct _NSZone *)zone
{
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        _sharedSingleton = [super allocWithZone:zone];
    });
    return _sharedSingleton;
}
-(id)init
{
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
        _sharedSingleton = [super init];
    });
    return _sharedSingleton;
}
+(instancetype)sharedInstance
{
    return [[self alloc]init];
}
+(id)copyWithZone:(struct _NSZone *)zone
{
    return _sharedSingleton;
}
+(id)mutableCopyWithZone:(struct _NSZone *)zone
{
    return _sharedSingleton;
}
@end


调用

//
//  ViewController.m
//  TestSingleton
//
//  Created by taobaichi on 2017/4/13.
//  Copyright © 2017年 MaChao. All rights reserved.
//
#import "ViewController.h"
#import "Singleton.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad {
    [super viewDidLoad];
    [self testSingleton];
}
-(void)testSingleton
{
    Singleton * single1 = [[Singleton alloc]init];
    Singleton * single2 = [[Singleton alloc]init];
    if (single1 == single2) {
        NSLog(@"single1 == single2");
    }
    NSLog(@"single1地址   %@",single1);
    NSLog(@"single2地址   %@",single2);
}
- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}
@end


打印结果

2017-04-13 13:20:31.480 TestSingleton[2562:111462] single1 == single2
2017-04-13 13:20:31.481 TestSingleton[2562:111462] single1地址   <Singleton: 0x608000012b00>
2017-04-13 13:20:31.481 TestSingleton[2562:111462] single2地址   <Singleton: 0x608000012b00>


相关文章
|
2月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
19天前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
111 66
|
6天前
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
|
30天前
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
|
1月前
|
Java 调度 Android开发
安卓与iOS开发中的线程管理差异解析
在移动应用开发的广阔天地中,安卓和iOS两大平台各自拥有独特的魅力。如同东西方文化的差异,它们在处理多线程任务时也展现出不同的哲学。本文将带你穿梭于这两个平台之间,比较它们在线程管理上的核心理念、实现方式及性能考量,助你成为跨平台的编程高手。
|
2月前
|
存储 前端开发 Swift
探索iOS开发:从新手到专家的旅程
本文将带您领略iOS开发的奇妙之旅,从基础概念的理解到高级技巧的掌握,逐步深入iOS的世界。文章不仅分享技术知识,还鼓励读者在编程之路上保持好奇心和创新精神,实现个人成长与技术突破。
|
2月前
|
安全 IDE Swift
探索iOS开发之旅:从初学者到专家
在这篇文章中,我们将一起踏上iOS开发的旅程,从基础概念的理解到深入掌握核心技术。无论你是编程新手还是希望提升技能的开发者,这里都有你需要的指南和启示。我们将通过实际案例和代码示例,展示如何构建一个功能齐全的iOS应用。准备好了吗?让我们一起开始吧!
|
2月前
|
设计模式 前端开发 JavaScript
JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式
本文深入探讨了JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式,结合电商网站案例,展示了设计模式如何提升代码的可维护性、扩展性和可读性,强调了其在前端开发中的重要性。
40 2
|
物联网 Android开发 iOS开发
iOS开发 - 蓝牙学习的总结
iOS开发 - 蓝牙学习的总结
193 0
|
iOS开发
IOS开发---菜鸟学习之路--(九)-利用PullingRefreshTableView实现下拉刷新
本章主要讲解如何利用PullingRefreshTableView实现下拉(上拉)刷新的操作  PullingRefreshTableView 实现上下拉刷新的例子百度有很多,大家可以自己搜索下,先看下那些例子(一般搜索过来的都是一样的大家反正先把那部分内容先了解一下,然后再看本文档比较好。
894 0