dispatch_after与performSelector延迟区别

 1.在主线程中

-(void)operationUse{
      dispatch_queue_t serialQueue = dispatch_queue_create("12312312", DISPATCH_QUEUE_CONCURRENT);

      dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0*NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
            NSLog(@"----4-----%@", [NSThread currentThread]);
        });
    
     [self performSelector:@selector(test1) withObject:nil afterDelay:0];
     [self performSelector:@selector(test2)];
   
}

-(void)test1{
     NSLog(@"----1-----%@", [NSThread currentThread]);
}
-(void)test2{
     NSLog(@"----2-----%@", [NSThread currentThread]);
}

2018-04-07 17:02:22.472123+0800 COCOCOCO[4207:170568] ----2-----<NSThread: 0x60000006b800>{number = 1, name = main}

2018-04-07 17:02:22.472923+0800 COCOCOCO[4207:170568] ----1-----<NSThread: 0x60000006b800>{number = 1, name = main}

2018-04-07 17:02:24.672263+0800 COCOCOCO[4207:170568] ----4-----<NSThread: 0x60000006b800>{number = 1, name = main}

这里延迟时间为0,但是如果当前线程有其他任务,优先让步给其他任务,执行等级相当于在主线程dispatch_async,把它的任务添加到队列末尾。

2.dispatch_after延迟时间与perform延迟时间一致谁先执行?

-(void)operationUse{
      dispatch_queue_t serialQueue = dispatch_queue_create("12312312", DISPATCH_QUEUE_CONCURRENT);

      dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0*NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
            NSLog(@"----4-----%@", [NSThread currentThread]);
        });
    
     [self performSelector:@selector(test1) withObject:nil afterDelay:2.0];
    // [self performSelector:@selector(test2)];
   
}

-(void)test1{
     NSLog(@"----1-----%@", [NSThread currentThread]);
}
-(void)test2{
     NSLog(@"----2-----%@", [NSThread currentThread]);
}
打印:2018-04-07 17:08:03.757620+0800 COCOCOCO[4266:174055] ----1-----<NSThread: 0x600000075a00>{number = 1, name = main}
2018-04-07 17:08:03.954315+0800 COCOCOCO[4266:174055] ----4-----<NSThread: 0x600000075a00>{number = 1, name = main}

看到虽然dispatch_after在perform前边,但是perform优先执行,因为dispatch_after是延迟提交,不是延迟运行

3.在子线程中两者的区别

-(void)operationUse{
      dispatch_queue_t serialQueue = dispatch_queue_create("12312312", DISPATCH_QUEUE_CONCURRENT);

    dispatch_async(serialQueue, ^{
        NSLog(@"----3-----%@", [NSThread currentThread]);
        
        dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0*NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
            NSLog(@"----4-----%@", [NSThread currentThread]);
        });
        [NSTimer scheduledTimerWithTimeInterval:2.0 target:self selector:@selector(test3) userInfo:nil repeats:NO];
        
        [self performSelector:@selector(test1) withObject:nil afterDelay:2.0];
        
    });
     [self performSelector:@selector(test2)];
   
}

-(void)test1{
     NSLog(@"----1-----%@", [NSThread currentThread]);
}
-(void)test2{
     NSLog(@"----2-----%@", [NSThread currentThread]);
}
-(void)test3{
     NSLog(@"----5-----%@", [NSThread currentThread]);
}
打印:2018-04-07 17:18:54.389757+0800 COCOCOCO[4398:181354] ----2-----<NSThread: 0x6000000799c0>{number = 1, name = main}
2018-04-07 17:18:54.389913+0800 COCOCOCO[4398:181576] ----3-----<NSThread: 0x604000465b80>{number = 3, name = (null)}
2018-04-07 17:18:56.392155+0800 COCOCOCO[4398:181354] ----4-----<NSThread: 0x6000000799c0>{number = 1, name = main}
可以看到perform与NSTimer没有执行,
只有主线程会在创建的时候默认自动运行一个runloop,并且有timer,普通的子线程是没有这些的。这样在子线程中被调用的时候,我们的代码中的延时调用的代码就会一直等待timer的调度,但是实际上在子线程中又没有这样的timer,这样我们的代码就永远不会被调到。因此,perform使用时需要注意环境!

4.如何在子线程调用perform和NStimer?

-(void)operationUse{
      dispatch_queue_t serialQueue = dispatch_queue_create("12312312", DISPATCH_QUEUE_CONCURRENT);

    dispatch_async(serialQueue, ^{
        @autoreleasepool {
            [NSThread currentThread].name = @"自定义线程名字";
            NSRunLoop * runloop = [NSRunLoop currentRunLoop];
            [runloop addPort:[NSPort port] forMode:NSDefaultRunLoopMode];
             [self performSelector:@selector(test1) withObject:nil afterDelay:2.0];
            
            [runloop run];
            
            [NSTimer scheduledTimerWithTimeInterval:2.0 target:self selector:@selector(test3) userInfo:nil repeats:NO];
        }
       
        
    });
     [self performSelector:@selector(test2)];
   
}
结果:2018-04-07 17:57:23.669567+0800 COCOCOCO[4778:202838] ----2-----<NSThread: 0x60400006a140>{number = 1, name = main}
2018-04-07 17:57:25.675078+0800 COCOCOCO[4778:202894] ----1-----<NSThread: 0x604000465340>{number = 3, name = 自定义线程名字}
perform执行了,NSTimer没有加入runloop中未执行
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
def write(self, vals): audit = self.env['approval.flow'].search([('approval_cannot_run_id', '=', '修改')]) value_list = list(vals.keys()) receive_list = [] value_list_not_in_receive_list = [i for i in value_list if i not in receive_list] value_list = value_list_not_in_receive_list # 应付 dispatch_number = 0 dispatch_id = self.env['roke.dispatch.order.management.price.approve'].search([('order_id.id', '=', self.id)]) dispatch_list = ['value03', 'value04', 'value05', 'value06', 'value07', 'value08'] if dispatch_id: for rec in value_list: for dispatch_list_id in dispatch_list: if rec == dispatch_list_id: if dispatch_id.approval_status != '未提' and dispatch_id.approval_status != '驳回': raise UserError("应付费用已开始审核不允许修改") value_list_not_in_dispatch_list = [i for i in value_list if i not in dispatch_list] value_list = value_list_not_in_dispatch_list dispatch_number = 1 break if dispatch_number: break # 基础 base_number = 0 base_list = ['client', 'department_manager', 'box_number', 'shipping_companies', 'field_station', 'ship_name_voyage', 'port_of_discharge', 'box_type', 'code', 'bill__of_lading_number', 'departure_date', 'lead_sealing', 'booking_time', 'date_of_pick_up', 'encore_date', 'set_port_date', 'estimated_range', 'destination_port_arrival_time'] if value_list: for rec in value_list: for base_list_id in base_list: if rec == base_list_id: if dispatch_id: if dispatch_id.approval_status != '未提' and dispatch_id.approval_status != '驳回': raise UserError("应付费用已开始审核不允许修改") base_number = 1 break if base_number: break return super(Rokedispatchordermanagement, self).write(vals) audit审核完成如果是修改不能修改如果不是可以修改怎么写可以实现
最新发布
06-13

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值