线程8--GCD常见用法

1.延迟执行

/***********************延迟第一种方法**************************/
    /* 第一种方法,
      调用NSObject的方法
     [self performSelector:@selector(run) withObject:nil afterDelay:2.0];
    @1.该方法在那个线程调用,那么run就在哪个线程执行(当前线程),通常是主线程。
    @2.如果把该方法放在异步函数中执行,则方法不会被调用

    */
//第一种方法:延迟3秒钟调用run函数
/*
     NSLog(@"打印线程----%@",[NSThread currentThread]);
    [self performSelector:@selector(run) withObject:nil afterDelay:2.0];
 */
/**********************延迟第二种方法**********************/

      /****************主队列***************/
    //可以安排其线程(1),主队列
    dispatch_queue_t queue=dispatch_get_main_queue();
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5.0*NSEC_PER_SEC)), queue, ^{
        NSLog(@"主队列--延迟执行----%@",[NSThread currentThread]);
    });
    /****************并发队列***************/
    //可以安排其线程(2),并发队列
    //1.获取全局并发队列
    dispatch_queue_t queue1=dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    //2.计算任务执行的时间
    dispatch_time_t when=dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5.0 * NSEC_PER_SEC));
    //3.会在when这个时间点,执行queue中的这个任务
        dispatch_after(when, queue1, ^{
            NSLog(@"并发队列-延迟执行----%@",[NSThread currentThread]);
        });

2.一次性代码

/**************************方法1*************************/
    //缺点:这是一个对象方法,如果又创建一个新的控制器,那么打印代码又会执行,因为每个新创建的控制器都有自己的布尔类型,且新创建的默认为NO,因此不能保证改行代码在整个程序中只打印一次。
    if (_log==NO) {
        NSLog(@"方法1一次性代码");
        _log=YES;
    }
/***************************方法2**************************/
    //使用dispatch_once函数能保证某段代码在程序运行过程中只被执行1次
    //整个程序运行过程中,只会执行一次。
    static dispatch_once_t once;
    dispatch_once(&once,^{
        NSLog(@"方法2一次性代码");// 只执行1次的代码(这里面默认是线程安全的)
    });

3.队列组

/*************************队列组**************************/
/*
 提示:使用队列组可以让图片1和图片2的下载任务同时进行,且当两个下载任务都完成的时候回到主线程进行显示。

 2.使用队列组解决
  步骤:
     2.1创建一个组
     2.2开启一个任务下载图片1
     2.3开启一个任务下载图片2
     2.4同时执行下载图片1\下载图片2操作
     2.5等group中的所有任务都执行完毕, 再回到主线程执行其他操作
*/
    NSLog(@"队列表开始下载");
    dispatch_group_t group=dispatch_group_create();
    /******************************************/
    //执行1个耗时的异步操作
    __block UIImage *image1=nil;

    dispatch_group_async(group,global_quque, ^{
        NSLog(@"图片1开始下载");
   image1=[self imageWithURL:@"http://a583.phobos.apple.com/us/r30/Purple4/v4/02/23/ec/0223ec03-ed8e-1c92-26c0-7dec34de6667/mzl.ksnlsaoo.175x175-75.png"];

    NSLog(@"图片1下载完成--%@",[NSThread currentThread]);
     });
   /*******************************************/
    //执行1个耗时的异步操作
    __block UIImage *image2=nil;
    dispatch_group_async(group, global_quque, ^{
        NSLog(@"图片2开始下载");
        image2=[self imageWithURL:@"http://img3.imgtn.bdimg.com/it/u=1790102556,3036052735&fm=21&gp=0.jpg"];
        NSLog(@"图片2下载完成--%@",[NSThread currentThread]);

    });
   /********************************************/
    // 等前面的异步操作都执行完毕后,回到主线程...
    dispatch_group_notify(group, main_queue, ^{
        self.imageView1.image=image1;
        self.imageView2.image=image2;
        UIGraphicsBeginImageContextWithOptions(CGSizeMake(200, 100), NO, 0);
        [image1 drawInRect:CGRectMake(0, 0, 100, 100)];
        [image2 drawInRect:CGRectMake(100, 0, 100, 100)];
        self.imageView3.image=UIGraphicsGetImageFromCurrentImageContext();
        UIGraphicsEndImageContext();
        NSLog(@"图片合并完成%@",[NSThread currentThread]);
    });
/**************************************************************/
-(UIImage*)imageWithURL:(NSString*)urlstr{
    NSURL *url=[NSURL URLWithString:urlstr];
    NSData *data=[NSData dataWithContentsOfURL:url];
    UIImage *image=[UIImage imageWithData:data];
    return image;
}
时间: 2024-11-10 01:17:42

线程8--GCD常见用法的相关文章

ios多线程 -- GCD 常见用法

GCD 通信操作 #pragma mark - GCD 通信 - (void)sendMessage{ dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ //耗时操作 [self downLoad:@"http://..."]; //回主队列刷新数据 dispatch_async(dispatch_get_main_queue(), ^{ //刷新UI操作 }); }); }

ios多线程开发 GCD常见用法

1-延迟执行 可以安排其线程(1),主队列 dispatch_queue_t queue= dispatch_get_main_queue(); dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5.0 * NSEC_PER_SEC)), queue, ^{ NSLog(@"主队列--延迟执行------%@",[NSThread currentThread]); }); 可以安排其线程(2),并发队列 1.获取全局并发

iOS开发多线程篇—GCD的常见用法

iOS开发多线程篇—GCD的常见用法 一.延迟执行 1.介绍 iOS常见的延时执行有2种方式 (1)调用NSObject的方法 [self performSelector:@selector(run) withObject:nil afterDelay:2.0]; // 2秒后再调用self的run方法 (2)使用GCD函数 dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispat

iOS开发多线程篇 08 —GCD的常见用法

iOS开发多线程篇—GCD的常见用法 一.延迟执行 1.介绍 iOS常见的延时执行有2种方式 (1)调用NSObject的方法 [self performSelector:@selector(run) withObject:nil afterDelay:2.0]; // 2秒后再调用self的run方法 (2)使用GCD函数 dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispat

iOS-多线程dispatch_semaphore_t dispatch_queue_t dispatch_group_t常见用法场景

dispatch_semaphore_t用法,dispatch_semaphore_create创建信号量实际就是创建的对象设置最大并发数.不得小于0, 小于0导致崩溃,dispatch_semaphore_wait, 减少一个信号量, 比如创建的对象信号量是5, wait一次就减少一个信号量,信号量变为4, 当信号量为0的时候当前线程就会等待,直到信号量>0的时候才会往下进行.dispatch_semaphore_signal增加一个信号量,减少与增加信号量是成对出现的. dispatch_s

iOS开发——多线程OC篇&(八)多线程GCD高级用法

GCD的常见用法 一.延迟执行 1.介绍 iOS常见的延时执行有2种方式 (1)调用NSObject的方法 [self performSelector:@selector(run) withObject:nil afterDelay:2.0]; // 2秒后再调用self的run方法 (2)使用GCD函数 dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_mai

iOS多线程技术—GCD的用法

iOS多线程技术—GCD的用法 一.主队列介绍 主队列:是和主线程相关联的队列,主队列是GCD自带的一种特殊的串行队列,放在主队列中得任务,都会放到主线程中执行. 提示:如果把任务放到主队列中进行处理,那么不论处理函数是异步的还是同步的都不会开启新的线程. 获取主队列的方式: 1 // 2 // YYViewController.m 3 // 12-GCD的基本使用(主队列) 4 // 5 // Created by 孔医己 on 14-6-25. 6 // Copyright (c) 2014

浅聊JAVA 线程池的一般用法

一.为什么要用线程池 1).降低资源消耗,通过重复利用已创建的线程降低线程的创建和销毁造成的消耗. 2).提高响应速度,当任务到达时,任务可以不需要等到线程创建就能立即执行. 3).提高线程的可管理性,线程是稀缺资源,如果无限制的创建,不仅会消耗系统资源,还会降低系统的稳定性,使用线程池可以进行统一的分配,调优和监控. 二.注意 1).需要对线程池原理了如指掌. 三.线程的常见用法 1).New Thread. 2).Thread Pool. 四.New Thread 常见用法 new  thr

GCD的用法

单例的实现 + (BindingRedResourceWIndow *)sharedInstance { static id sharedInstance = nil; static dispatch_once_t onceToken; dispatch_once(&onceToken,^{ sharedInstance = [[self alloc] initWithFrame:[[UIScreen mainScreen] bounds]]; }); //    [sharedInstance

RxAndroid 常见用法

RxAndroid 常见用法 在项目里面添加 compile 'io.reactivex:rxandroid:1.1.0' // Because RxAndroid releases are few and far between, it is recommended you also // explicitly depend on RxJava's latest version for bug fixes and new features. compile 'io.reactivex:rxja