zoukankan      html  css  js  c++  java
  • 自定义nsoperation的用法

    #import <Foundation/Foundation.h>
    
    typedef  void (^DownloadCompletionBlock)(UIImage *image);
    
    @interface DownloadOperation : NSOperation
    // 图片的url地址
    @property (nonatomic, copy) NSString *url;
    // retain对block没有作用,只能用copy
    @property (nonatomic, copy) DownloadCompletionBlock downloadCompletionBlock;
    @end
    
    
    ============================
    
    #import "DownloadOperation.h"
    
    @implementation DownloadOperation
    
    #pragma mark 在这里添加想要执行的操作
    - (void)main {
        // main方法可能在异步线程调用,这样就不恩能够访问主线程的自动释放池
        // 因此,在这里新建一个属于当前线程的自动释放池
        @autoreleasepool {
            // 取消操作发生在任何时刻都有可能,因此在执行任何操作之前,先检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:self.url]];
            // 执行了比较耗时的操作后也需要检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            // 调用Block,传递图片出去
            if (_downloadCompletionBlock) {
                UIImage *image = [UIImage imageWithData:data];
                
                dispatch_queue_t queue = dispatch_get_main_queue();
                dispatch_sync(queue, ^{
                    _downloadCompletionBlock(image);
                });
             }
        }
    }
    
    - (void)dealloc {
        [_url release];
        [_downloadCompletionBlock release];
        [super dealloc];
    }
    @end
    #import "DownloadOperation.h"
    
    @implementation DownloadOperation
    
    #pragma mark 在这里添加想要执行的操作
    - (void)main {
        // main方法可能在异步线程调用,这样就不恩能够访问主线程的自动释放池
        // 因此,在这里新建一个属于当前线程的自动释放池
        @autoreleasepool {
            // 取消操作发生在任何时刻都有可能,因此在执行任何操作之前,先检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:self.url]];
            // 执行了比较耗时的操作后也需要检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            // 调用Block,传递图片出去
            if (_downloadCompletionBlock) {
                UIImage *image = [UIImage imageWithData:data];
                
                dispatch_queue_t queue = dispatch_get_main_queue();
                dispatch_sync(queue, ^{
                    _downloadCompletionBlock(image);
                });
             }
        }
    }
    
    - (void)dealloc {
        [_url release];
        [_downloadCompletionBlock release];
        [super dealloc];
    }
    @end
    =========================================
    
    #import "DownloadOperation.h"
    
    @implementation DownloadOperation
    
    #pragma mark 在这里添加想要执行的操作
    - (void)main {
        // main方法可能在异步线程调用,这样就不恩能够访问主线程的自动释放池
        // 因此,在这里新建一个属于当前线程的自动释放池
        @autoreleasepool {
            // 取消操作发生在任何时刻都有可能,因此在执行任何操作之前,先检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:self.url]];
            // 执行了比较耗时的操作后也需要检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            // 调用Block,传递图片出去
            if (_downloadCompletionBlock) {
                UIImage *image = [UIImage imageWithData:data];
                
                dispatch_queue_t queue = dispatch_get_main_queue();
                dispatch_sync(queue, ^{
                    _downloadCompletionBlock(image);
                });
             }
        }
    }
    
    - (void)dealloc {
        [_url release];
        [_downloadCompletionBlock release];
        [super dealloc];
    }
    @end
    #import "DownloadOperation.h"
    
    @implementation DownloadOperation
    
    #pragma mark 在这里添加想要执行的操作
    - (void)main {
        // main方法可能在异步线程调用,这样就不恩能够访问主线程的自动释放池
        // 因此,在这里新建一个属于当前线程的自动释放池
        @autoreleasepool {
            // 取消操作发生在任何时刻都有可能,因此在执行任何操作之前,先检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:self.url]];
            // 执行了比较耗时的操作后也需要检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            // 调用Block,传递图片出去
            if (_downloadCompletionBlock) {
                UIImage *image = [UIImage imageWithData:data];
                
                dispatch_queue_t queue = dispatch_get_main_queue();
                dispatch_sync(queue, ^{
                    _downloadCompletionBlock(image);
                });
             }
        }
    }
    
    - (void)dealloc {
        [_url release];
        [_downloadCompletionBlock release];
        [super dealloc];
    }
    @end
    =========================================
    
    #import "DownloadOperation.h"
    
    @implementation DownloadOperation
    
    #pragma mark 在这里添加想要执行的操作
    - (void)main {
        // main方法可能在异步线程调用,这样就不恩能够访问主线程的自动释放池
        // 因此,在这里新建一个属于当前线程的自动释放池
        @autoreleasepool {
            // 取消操作发生在任何时刻都有可能,因此在执行任何操作之前,先检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:self.url]];
            // 执行了比较耗时的操作后也需要检测该操作是否已经被取消
            if (self.isCancelled) {
                return;
            }
            
            // 调用Block,传递图片出去
            if (_downloadCompletionBlock) {
                UIImage *image = [UIImage imageWithData:data];
                
                dispatch_queue_t queue = dispatch_get_main_queue();
                dispatch_sync(queue, ^{
                    _downloadCompletionBlock(image);
                });
             }
        }
    }
    
    - (void)dealloc {
        [_url release];
        [_downloadCompletionBlock release];
        [super dealloc];
    }
    @end
  • 相关阅读:
    JDK的KeyTool和KeyStore等加密相关
    关于分布式事务的随笔[待续]
    Netty实例几则
    Disruptor快速入门
    Java获取系统环境信息
    JDK的BIO, NIO, AIO
    四种常用IO模型
    JDK的多线程与并发库
    递归转换为迭代的一种通用方式
    二叉树的java实现
  • 原文地址:https://www.cnblogs.com/gcb999/p/3157522.html
Copyright © 2011-2022 走看看