Dispatch 方法简介

后台执行

dispatch_async(dispatch_get_global_queue(0, 0), ^{ 
    //后台程执行 something; 
}); 

主线程执行

dispatch_async(dispatch_get_main_queue(), ^{
    // 主线程执行something;
});

 

一次性执行

static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{ 
    // 主要用于单例
});

 

延迟执行

double delayInSeconds = 2.0;
dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, delayInSeconds * NSEC_PE R_SEC);
dispatch_after(popTime, dispatch_get_main_queue(), ^(void){ 
    // code to be executed on the main queue after delay
});

 

创建自定义的线程

dispatch_queue_t myQueue = dispatch_queue_create("com.cnblogs.yybz", NULL); dispatch_async(myQueue, ^{
    // your code
});

 

设置自定义线程的优先级

 

dispatch_queue_t myQueue = dispatch_queue_create("com.cnblogs.yybz", NULL); 
dispatch_queue_t globalHightQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0); 
dispatch_set_target_queue(myQueue, globalHighQueue);

 

 

dispatch_group_async(group, queue, ^{ 
    // code
}); 

dispatch_group_wait(group, DISPATCH_TIME_FOREVER); //超时参数 
dispatch_group_notify(group, queue, ^{
    // code
});

dispatch_group_enter(group);
dispatch_async(queue, ^{
    //code
    dispatch_group_leave(group);
});

 

并行同步执行

/**
@parameter iterations 迭代器数量
@parameter queue 提交任务的队列
@parameter (^block)(size_t) 任务Block,size_t 为迭代器下标
**/
dispatch_apply(size_t iterations, dispatch_queue_t queue, void (^block)(size_t));

 

队列挂起与恢复

dispatch_suspend(queue); 
dispatch_resume(myQueue);

 

信号量

dispatch_semaphore_create; //创建一个semaphore
dispatch_semaphore_signal; //发送一个信号
dispatch_semaphore_wait; //等待信号 

 

转载于:https://www.cnblogs.com/yybz/p/4043328.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值