zoukankan      html  css  js  c++  java
  • objective里面的单例模式

    在java程序中,最常用的就是单例模式,这个在objective-c一样可以使用,但是和java还是有一点区别。

    简单看一下java里面如何定义一个单例模式

    public class SingletonClass {

    private static SingletonClass instance = null;

    private SingletonClass(){

    }

    public static final getInstance(){

    synchorinzed(this){

    if(instance == null){

    instance = new SingletonClass();

    }

    return instance

    }

    }

    }

    在ios开发中,还是有一点区别的。在objective-c中,对象都是可以通过 [SingletonClass alloc]进行内存分配的,这样就可以返回一个新的实例对象,并且alloc方法都是public的,没有不让类进行调用,所以必须重写alloc的方法。

    一般情况下,alloc方法都是调用 +(id)allocWithZone:(Zone *) zone 进行初始化的,所以只需要在 allicWithZone里面进行初始化状态的判断即可

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    +(id) allocWithZone:(NSZone *)zone{
     
    if( instance == nil){
     
    instance = [super allocWithZone:zone ];
     
    }
     
    return instance;
     
    }

    在objective-c里面,alloc 方法是 负责给类的实例分配内存地址,简单说,就是初始化实例成员的内存地址,这个地址是根据 初始地址 + 偏移地址 来进行计算的。其实在java里面,也会有这个过程,只不过java在静态语言,在编译成clas文件里面的时候,类里面的所有实例属性都记录在一个 变量表里面,一般是通过变量表 间接关联到对应的对应的实际地址。而objective-c则是根据类属性相对于基础地址的偏移来进行计算的

    这个是比较好理解的 ,比如我们定义了一个 int * p 一个指针,如果使用p[5],则是相对p这个指针指向的地址 + 2 *5 作为p[5] 的地址。

    在alloc方法只是给实例变量分配内存地址,并且将其retain计数增加1 ,这个时候对于指针变量,其地址指向的值都还是nil的,想要初始化,则是通过 init开头的方法进行初始化的。在objective-c里面,分配地址和初始化是分开进行的,java里面的 new 关键字包括分配地址 加 初始化的过程,类似java里面的构造函数。但是objective-c 都是公开的,没有java里面的私有构造函数这个说法。

    作者:猫叔玩流量
    14年互联网技术、产品、运营经验,前支付宝技术专家,互金创业公司CTO,大令保事业部总经理。
    在互金领域有比较强的产品以及运营经验,尤其擅长用户增长、转化、运营上的经验,兼具技术、产品、运营思维。
    目前是云猫增长实验室 创始人

    云猫增长实验室是一家致力于帮助中小企业主、个人品牌提升流量运营能力的增长团队。
    团队成员来自阿里等国内知名互联网公司,曾在互联网金融、互联网保险、企业级SaaS等项目中负责用户增长,团队管理的工作,拥有丰富的一线流量增长经验与实操手段。

    欢迎关注我们,用技术驱动增长

    B站专栏:云猫增长实验室
    本人版权归作者和博客园所有,欢迎转载,转载请注明出处

  • 相关阅读:
    LeetCode:Symmetric Tree
    LeetCode:Construct Binary Tree from Inorder and Postorder Traversal,Construct Binary Tree from Preorder and Inorder Traversal
    LeetCode:Binary Tree Level Order Traversal I II
    LeetCode:Binary Tree Zigzag Level Order Traversal
    LeetCode:Convert Sorted Array to Binary Search Tree,Convert Sorted List to Binary Search Tree
    LeetCode:Balanced Binary Tree
    LeetCode:Minimum Depth of Binary Tree,Maximum Depth of Binary Tree
    LeetCode:Path Sum I II
    LeetCode:Flatten Binary Tree to Linked List
    LeetCode:Distinct Subsequences
  • 原文地址:https://www.cnblogs.com/aigongsi/p/2876022.html
Copyright © 2011-2022 走看看