• iOS 学习


    说明:转自文顶顶

    一、使用 for 循环

     要遍历字典、数组或者是集合,for 循环是最简单也用的比较多的方法

    -(void)iteratorWithFor
    {
        //////////处理数组//////////
        NSArray *arrayM = @[@"1",@"2",@"3",@"4"];
        NSInteger arrayMCount = [arrayM count];
        for (int i = 0; i<arrayMCount; i++) {
            NSString *obj = arrayM[i];
            NSLog(@"%@",obj);
        }
        
        //////////处理字典//////////
        NSDictionary *dictM = @{@"1":@"one",@"2":@"two",@"3":@"three"};
        NSArray *dictKeysArray = [dictM allKeys];
        for (int i = 0; i<dictKeysArray.count; i++) {
            NSString *key = dictKeysArray[i];
            NSString *obj = [dictM objectForKey:key];
            NSLog(@"%@:%@",key,obj);
        }
        
        //////////处理集合//////////
        NSSet * setM = [[NSSet alloc] initWithObjects:@"one",@"two",@"three",@"four", nil];
        NSArray *setObjArray = [setM allObjects];
        for (int i = 0; i<setObjArray.count; i++) {
            
            NSString *obj = setObjArray[i];
            NSLog(@"%@",obj);
        }
        
        //////////反向遍历----降序遍历----以数组为例
        NSArray *arrayM2 = @[@"1",@"2",@"3",@"4"];
        NSInteger arrayMCount2 = [arrayM2 count] - 1;
        
        for (NSInteger i = arrayMCount2; i>0; i--) {
            NSString *obj = arrayM2[i];
            NSLog(@"%@",obj);
        }
    }

    优点:简单

    缺点:由于字典和集合内部是无序的,导致我们在遍历字典和集合的时候需要借助一个新的【数组】作为中介来处理,多出一部分开支

     二、使用 for...in遍历

    在Objective-C 2.0 中增加了 for...in 形式的快速遍历,此种遍历方式语法简洁,速度飞快。

    //-->处理数组
        NSArray *arrayM = @[@"1",@"2",@"3",@"4"];
        for (id obj in arrayM) {
            NSLog(@"%@",obj);
        }
    //-->处理字典(有序)
        NSDictionary *dictM = @{@"1":@"one",@"2":@"two",@"3":@"three",@"4":@"four"};
        NSArray *array = [dictM allKeys];
        NSArray *sortArray = [array sortedArrayUsingComparator:^NSComparisonResult(id  _Nonnull obj1, id  _Nonnull obj2) {
            return [obj1 compare:obj2 options:NSNumericSearch];
        }];
        for (id obj in sortArray) {
            NSLog(@"%@",dictM[obj]);
        }

    优点:1)语法简洁;2)效率最高

    缺点:无法获得当前遍历操作所针对的下标。

    三、基于Block的遍历方式 

    基于Block的方式来进行遍历是最新引入的方法。它提供了遍历数组|字典等类型数据的最佳实践。

    -(void)iteratorWithBlock{
        //-->处理数组
        NSArray *arrayM = @[@"1",@"2",@"3",@"4"];
        [arrayM enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
            NSLog(@"%zd--%@",idx,obj);
        }];
        //-->处理字典
        NSDictionary *dictM = @{@"1":@"one",@"2":@"two",@"3":@"three",@"4":@"four"};
        [dictM enumerateKeysAndObjectsUsingBlock:^(id  _Nonnull key, id  _Nonnull obj, BOOL * _Nonnull stop) {
            NSLog(@"%@:%@",key,obj);
        }];
        //-->处理集合
        NSSet *setM = [[NSSet alloc]initWithObjects:@"one",@"two",@"three",@"four", nil];
        [setM enumerateObjectsUsingBlock:^(id  _Nonnull obj, BOOL * _Nonnull stop) {
            NSLog(@"%@",obj);
        }];
        //-->反向遍历---降序遍历---以数组为例
        NSArray *arrayM2 = @[@"1",@"2",@"3",@"4"];
        [arrayM2 enumerateObjectsWithOptions:NSEnumerationReverse usingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
            NSLog(@"%zd--%@",idx,obj);
        }];
    }

    优点:1)遍历时可以直接从 block 中获得需要的所有信息,包括下标、值等。特别相对字典而言,不需要做多余的编码即可同时获取key和value的值。

             2)能够直接修改 block 中key或者 obj 的类型为真实类型,可以省去类型转换的工作。

             3)可以通过 NSEnumerationConcurrent 枚举值开启并发迭代功能。

    说明:基于 Block 的遍历方式在实现反向遍历的时候也非常简单,使用 enumerateObjectsWithOptions 方法,传递 NSEnumerationReverse 作为参数即可,在处理遍历操作的时候基于 Block 的遍历方式。

    四、使用 GCD 中的 dispatch_apply函数

      使用GCD中的dispatch_apply函数也能实现字典、数组等的遍历,该函数比较适合处理耗时较长、迭代次数较多的情况。示例如下:

    -(void)iteratorWithAplly{
        //-->处理数组
        NSArray *arrayM = @[@"1",@"2",@"3",@"4"];
        //获得全局并发队列
        dispatch_queue_t queue = dispatch_get_global_queue(0, 0);
        
        dispatch_apply(arrayM.count, queue, ^(size_t index) {
            NSLog(@"%@---%@",arrayM[index],[NSThread currentThread]);
        });
    }

    优点:开启多条线程并发处理遍历任务,执行效率高。

    缺点:1)对于字典和集合的处理需借助数组;2)无法实现反向遍历。

  • 相关阅读:
    Nothing
    交换机基础
    BringWindowToTop(), SetForegroundWindow(), SetActiveWindow()
    NYOJ 38 布线问题_(解法2 Prim算法)
    Cocos2d-x3.0TestCpp文件夹笔记(二)
    SqlServer禁用启用触发器、外键约束
    Qt之zip压缩/解压缩(QuaZIP)
    Qt中用QuaZip来压缩和解压缩文件
    Qt 之 ZIP开源库 QuaZIP
    sqlserver 获取存储过程执行时间
  • 原文地址:https://www.cnblogs.com/asamu/p/5384750.html
Copyright © 2020-2023  润新知