美文网首页
你不知道的集合类

你不知道的集合类

作者: tinghua | 来源:发表于2019-06-25 21:24 被阅读0次

Foundation框架中的集合类,一般使用到的是集合、字典、数组以及它们的可变版本,NSCache, NSHashTable, NSMapTable 了解一下。

NSCache是专门用来处理内存缓存的类,使用方法跟NSMutableDictionary类似,但却又有很大的不同:

  1. NSMutableDictionary会对key进行copy,value retain, NSCache不会对key进行copy, 所以NSMutableDictionary的key要遵守NSCopy协议。
  2. NSCache线程安全, NSMutableDictionary非线程安全。
  3. NSCache有对象淘汰策略,通过在存值的时候指定cost,当总cost或者key-value个数达到limit时,会进行对象释放(非LRU算法)。这种淘汰策略在没收到内存警告是也会执行,从而降低内存峰值(minimizing its memory footprint)。
  4. Retrieving something from an NSCache object returns an autoreleased result.

NSHashTable

NSHashTable 是 NSSet 的通用版本,和 NSSet / NSMutableSet 不同的是,NSHashTable 具有下面这些特性:

  1. NSSet / NSMutableSet 持有成员的强引用,通过 hash 和 isEqual: 方法来检测成员的散列值和相等性。
  2. NSHashTable 是可变的,没有不可变的对应版本。
  3. NSHashTable 可以持有成员的弱引用。
  4. NSHashTable 可以在加入成员时进行 copy 操作。
  5. NSHashTable 可以存储任意的指针,通过指针来进行相等性和散列检查。
    NSHashTable 能保存对象弱引用, 对象释放后能从中移除用法。用法如下:
  • (void)hashTableTest {
    _hash = [NSHashTable hashTableWithOptions:NSPointerFunctionsWeakMemory];
    [_hash addObject:@"foo"];
    [_hash addObject:@"bar"];
    [_hash addObject:@42];
    [_hash addObject:@"bar"];
    Person *obj = [Person new];
    NSLog(@"%p", obj);
    NSLog(@"Retain count is %ld", CFGetRetainCount((__bridge CFTypeRef)obj));
    [_hash addObject:obj];
    NSLog(@"Retain count is %ld", CFGetRetainCount((__bridge CFTypeRef)obj));
    NSLog(@"Members: %@", [_hash allObjects]);
    }

我们在viewdidload和viewWillAppear中分别调用[_hash allObjects],结果如下:

2018-09-23 19:26:48.341916+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33628:10708256] 0x600000015580
2018-09-23 19:26:48.342115+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33628:10708256] Retain count is 1
2018-09-23 19:26:48.342247+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33628:10708256] Retain count is 1
2018-09-23 19:26:48.342469+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33628:10708256] Members: (
"<Person: 0x600000015580>",
bar,
42,
foo
)
2018-09-23 19:26:48.342594+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33628:10708256] Members: (
"<Person: 0x600000015580>",
bar,
42,
foo
)
2018-09-23 19:26:48.348660+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33628:10708256] Person--dealloc
2018-09-23 19:26:48.385762+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33628:10708256] Members: (
bar,
42,
foo
)

对对象的内存管理参考NSPointerFunctions.Options

NSMapTable

NSMapTable 是 NSMutableDictionary 的增强版。和NSMutableDictionary 不同的是,NSMapTable 具有下面这些特性:

用法:

  • (void)maptableTest {
    id obj = [Person new];
    NSLog(@"Retain count is %ld", CFGetRetainCount((__bridge CFTypeRef)obj));
    _map = [NSMapTable mapTableWithKeyOptions:NSMapTableStrongMemory
    valueOptions:NSMapTableWeakMemory];
    [_map setObject:obj forKey:@"foo"];
    NSLog(@"Retain count is %ld", CFGetRetainCount((__bridge CFTypeRef)obj));
    NSLog(@"Keys: %@", [[_map keyEnumerator] allObjects]);
    }

在viewDidLoad和viewDidAppear中分别调用NSLog(@"Keys: %@", [[_map keyEnumerator] allObjects]); 打印如下:

2018-09-23 19:39:23.192198+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33761:10717870] Retain count is 1

2018-09-23 19:39:23.192397+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33761:10717870] Retain count is 1
2018-09-23 19:39:23.192623+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33761:10717870] Keys: (
foo
)
2018-09-23 19:39:23.192754+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33761:10717870] Keys: (
foo
)
2018-09-23 19:39:23.195027+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33761:10717870] Person--dealloc
2018-09-23 19:39:23.213502+0800 NSDictonary&NSMapTable&NSHashTable&NSCache[33761:10717870] Keys: (
)

对对象的内存管理参考NSMapTableOptions, 值得注意的是SDWebImage最新版中将图片缓存的NSCache换为了NSMapTable,能够有效降低内存峰值。

相关文章

  • 你不知道的集合类

    Foundation框架中的集合类,一般使用到的是集合、字典、数组以及它们的可变版本,NSCache, NSHas...

  • Java集合

    集合概述 •Java提供集合类,集合类主要负责保存、盛装其他数据,因此集合类也被称为容器类。所有集合类都位于jav...

  • 14. 集合类

    1. Kotlin的集合类 Kotlin的集合类分为可变集合类和不可变集合类 2. 常用的三种集合类 主要有三种:...

  • PHCollection

    父类:PHObject Photos的资源的集合和集合列表的抽象超类(父类)。 一、概述 你不应该创建或直接使用这...

  • Java 容器 - 一文详解HashMap

    Map 类集合 Java Map类集合,与Collections类集合存在很大不同。它是与Collection 类...

  • Collection 集合类

    Collection 集合类 java.util包中提供了一些集合类,这些集合类又称为容器;集合类和数组的区别在于...

  • 函数的定义和调用

    3.1 创建集合 kotlin没有采用自己的集合类,而是采用的标准的java集合类。在java集合类的基础上新增了...

  • Java集合类总结

    Java集合类 1.简介: java集合类包含在java.util包下集合类存放的是对象的引用,而非对象本身。集合...

  • 面试总结-Java高级篇

    Java面试总结 1.你用过哪些集合类? 大公司最喜欢问的Java集合类面试题 40个Java集合面试问题和答案 ...

  • Java集合类-集合类图谱

    数据结构在计算机知识体系中的重要性无需赘言,Java的jdk的集合类正是学习数据结构的很好素材。如果能把jdk的集...

网友评论

      本文标题:你不知道的集合类

      本文链接:https://www.haomeiwen.com/subject/fchfcctx.html