GCD 加信号量串行进行多次网络请求操作

printf("处理前创建信号量,开始循环异步请求操作\n");

// 1.创建一个串行队列,保证for循环依次执行
        dispatch_queue_t serialQueue = dispatch_queue_create("serialQueue", DISPATCH_QUEUE_SERIAL);

// 2.异步执行任务
dispatch_async(serialQueue, ^{
    // 3.创建一个数目为1的信号量,用于“卡”for循环,等上次循环结束在执行下一次的for循环
    dispatch_semaphore_t sema = dispatch_semaphore_create(1);

    for (int i = 0; i<5; i++) {
        // 开始执行for循环,让信号量-1,这样下次操作须等信号量>=0才会继续,否则下次操作将永久停止
        dispatch_semaphore_wait(sema, DISPATCH_TIME_FOREVER);
        printf("信号量等待中\n");
        // 模拟一个异步任务
        NSMutableURLRequest *urlRequest = [[NSMutableURLRequest alloc] initWithURL:[NSURL URLWithString:@"https://github.com"]];
        NSURLSession *session = [NSURLSession sharedSession];
        NSURLSessionDataTask *dataTask = [session dataTaskWithRequest:urlRequest completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response, NSError * _Nullable error) {
        // 本次for循环的异步任务执行完毕,这时候要发一个信号,若不发,下次操作将永远不会触发
            [tampArray addObject:@(i)];
            NSLog(@"本次耗时操作完成,信号量+1 %@\n",[NSThread currentThread]);
            dispatch_semaphore_signal(sema);

        }];
        [dataTask resume];

    }

    NSLog(@"其他操作");
    for (NSNumber *num in tampArray) {
        NSLog(@"所有操作完成后的操作--->   %@\n",num);
    }

});

双重信号量


        //上传最近的3个log文件,
        //至少要3个,因为最后一个是crash的记录信息,另外2个是防止其中后一个文件只写了几行代码而不够分析
        NSArray *logFilePaths = [fileLogger.logFileManager sortedLogFilePaths];
        
        NSUInteger logCounts = logFilePaths.count;
        
        if (logCounts >= 3) {
            
            dispatch_queue_t queue = dispatch_queue_create(0, DISPATCH_QUEUE_SERIAL);

            dispatch_semaphore_t semaphore = dispatch_semaphore_create(1);
            
            dispatch_async(queue, ^{
             
                for (NSUInteger i = 0; i < 3; i++) {
                    
                    dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);
                    
                    NSString *logFilePath = logFilePaths[i];
                    
                    //上传服务器
                    
                    NSData *file_total = [NSData dataWithContentsOfFile:logFilePath];
                    
                    KKLogDebug(@"上传服务器 logFilePath %@  %@",logFilePath,file_total);
                    
                    if(file_total.length > 0){
                        
                        NSMutableArray *dataArrM = [self uploadLogFileArrWithData:file_total];
                        
                        if(dataArrM.count > 0){

                            dispatch_queue_t queue_upload = dispatch_queue_create(0, DISPATCH_QUEUE_SERIAL);
                            
                            dispatch_semaphore_t semaphore_upload = dispatch_semaphore_create(1);
                            
                            dispatch_async(queue_upload, ^{

                                for(int j = 0; j < dataArrM.count; j++){

                                    dispatch_semaphore_wait(semaphore_upload, DISPATCH_TIME_FOREVER);
            
                                    NSData *data = dataArrM[i];
                                    
                                    KKLogDebug(@"+++++++++ %@ == %zd  %@ totalSize=%@",[NSString stringWithFormat:@"%lu",data.length * j],dataArrM.count,[NSThread currentThread],[NSString stringWithFormat:@"%zd",data.length]);
                                    
                                    [[[KKUtility fetchUploadFileLogWithContent:dataArrM[j] fileName:logFilePath ready:[NSString stringWithFormat:@"%zd",data.length * j+1] totalSize:[NSString stringWithFormat:@"%zd",data.length] status:@"0"] deliverOnMainThread] subscribeNext:^(NSDictionary *result) {
                                        
                                        if (j == dataArrM.count - 1) {
                                            dispatch_semaphore_signal(semaphore);
                                        }
                                        
                                        dispatch_semaphore_signal(semaphore_upload);
                                        
                                        KKLogDebug(@"result  %@",result);
                                        
                                    } error:^(NSError *error) {
                                        
                                        dispatch_semaphore_signal(semaphore);
                                        dispatch_semaphore_signal(semaphore_upload);
                                        KKLogError(@"%@",error);
                                    }];
                                }
                            });
                        }
                    }
                    else {
                        dispatch_semaphore_signal(semaphore);
                    }
                }
              });
              
        }

文件切片:

- (NSMutableArray *)uploadLogFileArrWithData:(NSData *)file_total
{
     NSUInteger allLength = file_total.length;
                          
      NSUInteger subs = 4096;//要切片的大小,

      NSInteger index = 0;//起始位置

      NSMutableArray *dataArray =[NSMutableArray new];
      
      do {

          if (allLength>subs) {
              
              NSRange range =NSMakeRange(index*subs, subs);
              
              index++;
              
//              KKLogDebug(@"%@",NSStringFromRange(range));
              
              [dataArray addObject:[file_total subdataWithRange:range]];
              
              allLength = allLength - subs;

          }else{
              
              NSRange range = NSMakeRange(index*subs, allLength);
              
//              KKLogDebug(@"%@",NSStringFromRange(range));
              
              [dataArray addObject:[file_total subdataWithRange:range]];

              allLength = 0;
          }

          
      } while (allLength>0);
      
//      KKLogDebug(@" dataArray %@",dataArray);//最后得到切片的结果,数组里面是NSData对象
     return dataArray;
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 229,732评论 6 539
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 99,214评论 3 426
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 177,781评论 0 382
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 63,588评论 1 316
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 72,315评论 6 410
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 55,699评论 1 327
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 43,698评论 3 446
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 42,882评论 0 289
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 49,441评论 1 335
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 41,189评论 3 356
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 43,388评论 1 372
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 38,933评论 5 363
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 44,613评论 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 35,023评论 0 28
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 36,310评论 1 293
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 52,112评论 3 398
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 48,334评论 2 377

推荐阅读更多精彩内容