Swift Array 元素个数判断为0的方法哪种更好

栏目: ASP.NET · 发布时间: 5年前

内容简介:在日常开发中,经常会遇到判断一个大致意思就是,当判断你的集合是否为空时,推荐使用首先,

在日常开发中,经常会遇到判断一个 Array 中元素个数是否为0。一般来说,有两种方法,一种是 isEmpty ,一种是 array.count == 0 。那哪一种方法更好呢?在苹果的官方文档中, isEmpty 方法上有这样一段注释

/// When you need to check whether your collection is empty, use the `isEmpty` property instead of checking that the `count` property equal to zero. 
 /// For collections that dont conform `RandomAccessCollection`, accessing the `count` property iterates through the elements of the collection.
 - Complexity: O(1)
复制代码

大致意思就是,当判断你的集合是否为空时,推荐使用 isEmpty 属性来代替判断 count 属性是否等于0。因为集合类型的 count 属性会遍历集合里的所有元素。 isEmpty 属性的时间复杂度为O(1)。 接下来我们就从源代码角度来分析一下这2者的区别吧。以下的代码位于 githubstdlib/public/core/Collection.swift 文件里。

public protocol Collection: Sequence {
	var isEmpty: Bool { get }
	var count: Int { get }
	
	var startIndex: Index { get }
	var endIndex: Index { get }
}
复制代码

首先, isEmptycount 都是 Collection 协议的计算型属性。其次,都有一个默认实现。

isEmpty 实现

extension Collection {
	public var isEmpty: Bool {
   		return startIndex == endIndex
  	}
}
复制代码

isEmpty 方法的实现很简单,判断 startIndexendIndex 是否相等就可以了。那 startIndexendIndex 又是2个计算型属性,那么这2个的实现又是怎么样的呢?在这个文件里我们没有找到默认实现,所以我们就前往同层文件夹的 Array.swift 文件里去查看一下了。 startIndex 的实现很简单,直接返回了一个 0

public var startIndex: Int {
    return 0
  }
复制代码

endIndex 的相对就稍微复杂一点了

@inlinable
public var endIndex: Int {
	@inlinable
    get {
      	return _getCount()
    }
 }
  
internal func _getCount() -> Int {
	return _buffer.count
}
复制代码

看到这儿,里面的再看下去就太深了(我也看不明白了),姑且当作 _bufferArray 类型的内部实现吧。

count 实现

public var count: Int {
	return distance(from: startIndex, to: endIndex)
}

public func distance(from start: Index, to end: Index) -> Int {
    _precondition(start <= end,
                  "Only BidirectionalCollections can have end come before start")
    
    var start = start
    var count = 0
    while start != end {
        count = count + 1
        formIndex(after: &start)
    }
    return count
}
复制代码

count 方法内部调用了一个 distance(from:to:) 的方法,而且在 distance 内部有一个 while 循环遍历直到 start==end ,那么 count 的事件复杂度就是 o(n)

因此2个属性相比,在使用的时候,最好还是使用 isEmpty 属性判断 Array 元素是否为空。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

疯传

疯传

乔纳·伯杰 (Jonah Berger) / 刘生敏、廖建桥 / 电子工业出版社 / 2014-1-1 / CNY 48.00

《疯传:让你的产品、思想、行为像病毒一样入侵》内容简介:是什么让事物变得流行?从买轿车、买衣服、吃三明治,到给孩子取名字,你是否知道为什么某些产品会大卖,某些故事被人们口口相传,某些电子邮件更易被转发,或者某些视频链接被疯狂地点击,某些谣言更具传播力,某些思想和行为像病毒一样入侵你的大脑……《疯传:让你的产品、思想、行为像病毒一样入侵》这本书将为你揭示这些口口相传和社会传播背后的科学秘密,并且告诉......一起来看看 《疯传》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具