zoukankan      html  css  js  c++  java
  • 多线程GCD的魔力

    GCD(Grand Central Dispatch)是一个大的主题。它可以提高代码的执行效率与多核的利用率。是苹果的开源项目,如果你是一个追求软件效率的开发人员,这门技术你一定要有所研究。

     

    今天要介绍的是如何从网上下载大量的文件, 方法有许多,传通的就是用多线程,面iOS中有很好用的Operator Queeu, 或者用传通的NStrhead, pthread. 今天我不介绍这些方法,而是得用GCD来完成这个下载任务。

     

    今天这个demo, 展示面几个功能:

     

    1. 预定义了大量的要下载的图片URL

    2. 创建一个GCD queue并开始下载图片

    3. 在动画出现消失的时候,同时显示图片

     

    主要代码:

        @interface UIImageView (DispatchLoad)  
        - (void) setImageFromUrl:(NSString*)urlString;  
        - (void) setImageFromUrl:(NSString*)urlString   
                      completion:(void (^)(void))completion;  
        @end  
    
     
    
        #import "UIImageView+DispatchLoad.h"  
        @implementation UIImageView (DispatchLoad)  
        - (void) setImageFromUrl:(NSString*)urlString {  
            [self setImageFromUrl:urlString completion:NULL];  
        }  
        - (void) setImageFromUrl:(NSString*)urlString   
                      completion:(void (^)(void))completion {  
              
            dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{  
                  
                NSLog(@"Starting: %@", urlString);  
                UIImage *avatarImage = nil;   
                NSURL *url = [NSURL URLWithString:urlString];  
                NSData *responseData = [NSData dataWithContentsOfURL:url];  
                avatarImage = [UIImage imageWithData:responseData];  
                NSLog(@"Finishing: %@", urlString);  
                  
                if (avatarImage) {  
                    dispatch_async(dispatch_get_main_queue(), ^{  
                        self.image = avatarImage;  
                    });  
                    dispatch_async(dispatch_get_main_queue(), completion);  
                }  
                else {  
                    NSLog(@"-- impossible download: %@", urlString);  
                }  
            });     
        }  
        @end  

     

    这只是一个简单展示GCD异步操作的demo,它的用武之地远不止这点。记住,最重要的是使用它后,即使我们的工作线程在处理很繁重的任务,也能使我们的UI很平滑。

     

    demo的源码可以在这儿下载

  • 相关阅读:
    angular11源码探索十四[表单校验器]
    2020年终总结
    vue使用腾讯地图获取当前位置
    腾讯地图+element-ui 实现地址搜索标记功能
    腾讯地图SDK公交路线规划Demo2
    腾讯地图SDK公交路线规划Demo
    腾讯位置服务地图SDK自定义路况和字体
    腾讯地图SDK自定义地图和路况
    3D地图的定时高亮和点击事件
    vue+腾讯地图 实现坐标拾取器功能
  • 原文地址:https://www.cnblogs.com/ligun123/p/2508182.html
Copyright © 2011-2022 走看看