zoukankan      html  css  js  c++  java
  • IOS开发(63)之GCD执行延迟操作

    1 前言

    使用Dispatch_after ,能够在你想指定一定数量的延迟之后,使用 GCD 来执行代码。今天我们就来学习一下。

    2 代码实例

    Demo1:

    ZYAppDelegate.m

    - (void) printString:(NSString *)paramString{
        NSLog(@"%@", paramString);
    }
    
    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
    {
        /*
         推迟三秒执行printString方法
         withObject:传的参数
         */
        [self performSelector:@selector(printString:) withObject:@"Grand Central Dispatch" afterDelay:3.0];
        self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];
        // Override point for customization after application launch.
        self.viewController = [[[ZYViewController alloc] initWithNibName:@"ZYViewController" bundle:nil] autorelease];
        self.window.rootViewController = self.viewController;
        [self.window makeKeyAndVisible];
        return YES;
    }

    运行3秒后控制台结果:

    2013-05-10 17:04:52.710 GCDAfterTest[2385:c07] Grand Central Dispatch

    Demo2:

    ZYAppDelegate.m

    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
    {
        //设置时间为2
        double delayInSeconds = 2.0;
        //创建一个调度时间,相对于默认时钟或修改现有的调度时间。
        dispatch_time_t delayInNanoSeconds =dispatch_time(DISPATCH_TIME_NOW, delayInSeconds * NSEC_PER_SEC);
        //推迟两纳秒执行
        dispatch_queue_t concurrentQueue =dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
        dispatch_after(delayInNanoSeconds, concurrentQueue, ^(void){
            NSLog(@"Grand Center Dispatch!");
        });
        
        self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];
        // Override point for customization after application launch.
        self.viewController = [[[ZYViewController alloc] initWithNibName:@"ZYViewController" bundle:nil] autorelease];
        self.window.rootViewController = self.viewController;
        [self.window makeKeyAndVisible];
        return YES;
    }

    运行2秒后控制台结果

    2013-05-10 17:06:27.023 GCDAfterTest2[2435:1303] Grand Center Dispatch!

    Demo3:

    ZYAppDelegate.m

    void processSomething(void *paramContext){
        NSLog(@"Processing...");
    }
    
    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
    {
        //设置时间
        double delayInSeconds = 2.0;
        dispatch_time_t delayInNanoSeconds =
        dispatch_time(DISPATCH_TIME_NOW, delayInSeconds * NSEC_PER_SEC);
        dispatch_queue_t concurrentQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
        //调用C函数processSomething
        dispatch_after_f(delayInNanoSeconds, concurrentQueue,
                         NULL,
                         processSomething);
        self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];
        // Override point for customization after application launch.
        self.viewController = [[[ZYViewController alloc] initWithNibName:@"ZYViewController" bundle:nil] autorelease];
        self.window.rootViewController = self.viewController;
        [self.window makeKeyAndVisible];
        return YES;
    }

    运行2秒后控制台结果

    2013-05-10 17:07:27.660 GCDAfterTest3[2476:1303] Processing...

    3 结语

    以上是所有内容,希望对大家有所帮助。

    Demo代码下载:http://download.csdn.net/detail/u010013695/5353603

  • 相关阅读:
    面向对象基础小结
    异常应用场景
    集合应用场景1:迭代器
    集合应用场景2——数据结构
    华为ce交换机 Bridge-Domain NVE
    linux 内核内置模块
    linux bridge 转发 ip
    iptables nat&conntrack
    loopback
    配置集中式网关部署方式的VXLAN示例(静态方式)
  • 原文地址:https://www.cnblogs.com/jiangu66/p/3073368.html
Copyright © 2011-2022 走看看