iOS开发多线程NSOperation(四)

2024-05-05 01:18

本文主要是介绍iOS开发多线程NSOperation(四),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

NSOperation 可以实现多线程 是一个抽象类 不能直接使用 实现的手段通过该类的子类 NSInvocationOperation NSBlockOperation 实现多线程
NSInvocationOperation 在创建任务时 用一个方法来表示 任务必须放在任务队列中管理 队列保持任务以先进先出的顺序

NSBlockOperation 创建任务时 用一个block来表示 


- (void)viewDidLoad {[super viewDidLoad];// Do any additional setup after loading the view, typically from a nib.//1.NSInvocationOperationNSInvocationOperation *operation1 = [[NSInvocationOperation alloc]initWithTarget:self selector:@selector(printA) object:nil];//operation1代表了任务printANSInvocationOperation *operation2 = [[NSInvocationOperation alloc]initWithTarget:self selector:@selector(printB) object:nil];//operation2代表了任务printB//2.NSBlockOperationNSBlockOperation  *blockOperation = [NSBlockOperation blockOperationWithBlock:^{[self printC];}];// blockOperation代表任务printC//3.创建任务 需要加到任务队列中管理 NSOperationQueue 任务队列 管理多个任务的//创建队列NSOperationQueue *queue = [[NSOperationQueue alloc]init];//设置任务的最大并发数(最多的时候有几个任务同时进行)queue.maxConcurrentOperationCount = 4;//B添加依赖 依赖于A 添加依赖 需要写在加入队列之前[operation2 addDependency:operation1];[blockOperation addDependency:operation2];
/*//C--> A -->B//A依赖于C B依赖于A[operation1 addDependency:blockOperation];[operation2 addDependency:operation1];
*///给队列添加任务[queue addOperation:operation1];[queue addOperation:operation2];[queue addOperation:blockOperation];//【注意】任务需要加入队列才能执行 否则没有效果//如果需要将某些任务排序 按照一个固定的顺序执行 可以添加任务间的依赖关系//A-->B B的执行先决条件是A执行了 B依赖于A//希望取消任务 任务会终止 如果任务已经开始了
//    [queue cancelAllOperations];//主线程管理任务的主队列 应用程序启动 也会有//获取主队列NSOperationQueue *mainQueue = [NSOperationQueue mainQueue];NSLog(@"%@",mainQueue);//    [self mainPrint]; 说明 在生命周期的方法中调用的任务 都是添加到主队列中管理的//获取当前对列NSOperationQueue *currentQueue = [NSOperationQueue currentQueue];//给队列命名(可以用于判断当前执行的是哪一个队列中的方法 主队列名字@“NSOperationQueue main queue”)//    queue.name = @"MY_QUEUE";}- (void)mainPrint{NSOperationQueue *currentQueue = [NSOperationQueue currentQueue];NSLog(@"%@",currentQueue);//主队列
}- (void)printA{for (int i = 0; i < 5; i++) {NSLog(@"AAAAAAA");}
}- (void)printB{for (int i = 0; i < 5; i++) {NSLog(@"BBBBBBBB");}
}- (void)printC{for (int i = 0; i < 5; i++) {NSLog(@"CCCCCCC");}
}



这篇关于iOS开发多线程NSOperation(四)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/960500

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要