NSOperation多线程实现队列

本文介绍NSOperation和NSOperationQueue的基本概念、创建及使用方法。通过示例代码展示如何利用NSOperationQueue实现多线程任务调度,包括任务的添加、设置最大并发数等。

NSOperation:

//NSOperation和NSThread最主要的区别是:前者是通过创建线程池,把任务添加到线程池来实现多线程并发操作。通过NSOperationQueue可以设置任务的调度顺序和最大并发数,以此达到任务的相对独立运行,而NSThread是通过加锁的方式来保证线程间的独立运行,来保证数据的准确性。

1:NSOperation基本概念

2:NSOperation的创建

3:NSOperation的使用

NSOperation常用方法:

NSOperationQueue:任务队列

NSInocationOperation:任务对象类型

initWithTarget:创建任务

addOperation:operation:添加任务到队列中

setMaxConcurrentOperationCount:设置同时并发的任务数量

#import "ViewController.h"
@interface ViewController (){
    //定义一个任务队列对象
    NSOperationQueue *_oq;
}
@end
@implementation ViewController
- (void)viewDidLoad {
    [super viewDidLoad];
    NSArray *arr = @[@"添加新任务1到队列中",@"添加新任务2到队列中"];
    // Do any additional setup after loading the view, typically from a nib.
    for (int i=0; i<2; i++) {
        UIButton *btn = [UIButton buttonWithType:UIButtonTypeRoundedRect];
        btn.frame = CGRectMake(100, 100+i*80, 160, 40);
        [btn addTarget:self action:@selector(pressBtn:) forControlEvents:UIControlEventTouchUpInside];
        [btn setTitle:arr[i] forState:0];
        btn.tag = 100+i;
    }
    //创建一个任务队列对象
    _oq = [[NSOperationQueue alloc]init];
    //设置最大并发任务的数量
    [_oq setMaxConcurrentOperationCount:5];
}
- (void)pressBtn:(UIButton*)btn{
    if(btn.tag == 100){
        //创建一个执行任务
        //P1:任务函数的拥有者
        //P2:任务函数执行者
        //P3:参数
        NSInvocationOperation *iop = [[NSInvocationOperation alloc]initWithTarget:self selector:@selector(optAct1:) object:@"opt01"];
        [_oq addOperation:iop];
        
        NSInvocation *ivo = [[NSInvocation alloc]init];
        ivo.target = self;
        ivo.selector = @selector(optAct1:);
        NSInvocationOperation *iop2 = [[NSInvocationOperation alloc]initWithInvocation:ivo];
        [_oq addOperation:iop2];
    }else if(btn.tag == 101){
        //使用block语法快来进行任务处理
        [_oq addOperationWithBlock:^{
            while (true) {
                NSLog(@"opt 2");
            }
        }];
    }
}
- (void)optAct1:(NSInvocationOperation*)opt{
    while (true) {
        NSLog(@"opt 1");
    }
}
- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}






下载前可以先看下教程 https://pan.quark.cn/s/a426667488ae 标题“仿淘宝jquery图片左右切换带数字”揭示了这是一个关于运用jQuery技术完成的图片轮播机制,其特色在于具备淘宝在线平台普遍存在的图片切换表现,并且在整个切换环节中会展示当前图片的序列号。 此类功能一般应用于电子商务平台的产品呈现环节,使用户可以便捷地查看多张商品的照片。 说明中的“NULL”表示未提供进一步的信息,但我们可以借助标题来揣摩若干核心的技术要点。 在构建此类功能时,开发者通常会借助以下技术手段:1. **jQuery库**:jQuery是一个应用广泛的JavaScript框架,它简化了HTML文档的遍历、事件管理、动画效果以及Ajax通信。 在此项目中,jQuery将负责处理用户的点击动作(实现左右切换),并且制造流畅的过渡效果。 2. **图片轮播扩展工具**:开发者或许会采用现成的jQuery扩展,例如Slick、Bootstrap Carousel或个性化的轮播函数,以达成图片切换的功能。 这些扩展能够辅助迅速构建功能完善的轮播模块。 3. **即时数字呈现**:展示当前图片的序列号,这需要通过JavaScript或jQuery来追踪并调整。 每当图片切换时,相应的数字也会同步更新。 4. **CSS美化**:为了达成淘宝图片切换的视觉效果,可能需要设计特定的CSS样式,涵盖图片的排列方式、过渡效果、点状指示器等。 CSS3的动画和过渡特性(如`transition`和`animation`)在此过程中扮演关键角色。 5. **事件监测**:运用jQuery的`.on()`方法来监测用户的操作,比如点击左右控制按钮或自动按时间间隔切换。 根据用户的交互,触发相应的函数来执行...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值