IOS關于多張圖片上傳侮繁、地址返回順序問題

先看描述

需求是怎樣的:for 循環(huán)里面、多個網絡請求上傳圖片如孝,每次上傳一張宪哩,至于為什么每次只上傳一張呢,因為上傳一張將要返回圖片存儲服務器的地址第晰,然后再把地址作為請求參數锁孟,請求自己服務器的 API。

過程可以說曲折茁瘦,不過也有收獲

解決方案一:

遞歸調用上傳圖片的函數品抽、第一張請求成功后,然后第二張甜熔,依次進行圆恤。當然效率肯定不高,即使上傳圖片的AFN方法做了多線程處理腔稀。中間上傳失敗了盆昙,還繼續(xù)上傳嗎羽历?需求決定。所有放棄

解決方案二:

使用GCD 隊列組:這里就直接貼代碼了:

dispatch_group_t group =  dispatch_group_create();
   for(..){
        dispatch_group_async(group,dispatch_get_global_queue(0, 0), ^{
        NSLog(@"隊列組:有一個耗時操作完成淡喜!");
        });
      }
    
    dispatch_group_notify(group, dispatch_get_main_queue(), ^{
        NSLog(@"隊列組:前面的耗時操作都完成了秕磷,回到主線程進行相關操作");
    });

我只能說想法很完美啊,網上也不只提出這種方案炼团,但是我的實踐過程是有問題了澎嚣。網絡請求延遲,隊列組不可控瘟芝。所以放棄

方案三:利用數組的有序性:

怎么個利用法币叹?請看:

  1. 創(chuàng)建一個模型、兩個屬性第一個你要上傳的數據信息如:image 或者 data 模狭,根據你上傳函數需要的參數來定颈抚。第二個屬性:NSString URL 服務端返回的圖片地址:

2、將你要上傳的圖片數組嚼鹉、封裝成模型數組贩汉,數組是有序的這就是重點,for 循環(huán) 模型作為參數調用圖片上傳函數锚赤,請求成功后更新模型的值

3匹舞、判斷所有的圖片上傳完畢,然后线脚,就從模型數組里面去取 赐稽,圖片 url ,請求自己的服務器api

好了浑侥,應該很清楚吧姊舵。不清楚再上點干貨:

model:

// 建立這個類的目的、主要是為了for循環(huán)多張圖片上傳寓落、成功后回來的地址順序問題

#import <Foundation/Foundation.h>

@interface FMUploadModel : NSObject
//根據自己的上傳函數需要決定
@property (nonatomic,strong) NSArray * dataArray;

@property (nonatomic,copy) NSString *imgUrl;

@end

function

//開辟一個多線程 執(zhí)行圖片上傳工作
           dispatch_queue_t queue = dispatch_queue_create("upimgs", DISPATCH_QUEUE_CONCURRENT);

            dispatch_async(queue, ^{
                // 耗時操作放在這里
                
                __weak typeof(self) weakself = self;
                __block int finishNum = 0;
                for (int i = 0 ; i < self.selectImgs.count; i++) {
                    YRFormData *getData = [[YRFormData alloc] init];
                    getData.data = UIImagePNGRepresentation(self.selectImgs[i]);
                    getData.name = @"uzee_image";
                    getData.filename = @"head.png";
                    getData.mimeType = @"image/png";
                    NSArray *array = @[getData];
                    //***********//
                    FMUploadModel *model = [FMUploadModel new];
                    model.dataArray = array;
                    model.imgUrl = @"";
                    [models addObject:model];
                    /*******其實是一張一張傳的括丁,傳數組是調用這個方法**********/
                    [YRHttpTool postWithURLNoAES:@"*****" params:@{} formDataArray:model.dataArray success:^(id json) {
                        finishNum ++ ;
                        model.imgUrl = json[@"response"][@"cloud"];
                        if (finishNum == self.selectImgs.count) {
                            dispatch_async(dispatch_get_main_queue(), ^{
                                // 回到主線程進行UI操作
                                [MBProgressHUD hideHUDForView:weakself.view];
                                updateImage();
                            });
                            
                        }
                        
                    } failure:^(NSError *error) {
                        dispatch_async(dispatch_get_main_queue(), ^{
                            // 回到主線程進行UI操作
                            [MBProgressHUD hideHUDForView:weakself.view];
                            [MBProgressHUD showError:@"圖片上傳失敗,請稍后再試" toView:self.view];
                        });
                    } progress:^(NSProgress *progress) {
                        [[NSOperationQueue mainQueue] addOperationWithBlock:^{
                            
                            float value = 1.0 *progress.completedUnitCount / progress.totalUnitCount;
                            [MBProgressHUD showDownload:@"發(fā)布中..." toView:weakself.view progress:value];
                        }];
                        
                    }];
                    
                    
                }
            });

結語:

如果看完這篇文章伶选,對你有那么一絲的幫助史飞,請點贊,哈哈畢竟贊美是我天朝的美德嘛仰税,點一下又不會懷孕對不對构资。
如果你有更好的方案、歡迎提出來一起討論陨簇。

謝謝吐绵!

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子拦赠,更是在濱河造成了極大的恐慌巍沙,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件荷鼠,死亡現場離奇詭異句携,居然都是意外死亡,警方通過查閱死者的電腦和手機允乐,發(fā)現死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門矮嫉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人牍疏,你說我怎么就攤上這事蠢笋。” “怎么了鳞陨?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵昨寞,是天一觀的道長。 經常有香客問我厦滤,道長援岩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任掏导,我火速辦了婚禮享怀,結果婚禮上,老公的妹妹穿的比我還像新娘趟咆。我一直安慰自己添瓷,他們只是感情好,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布值纱。 她就那樣靜靜地躺著鳞贷,像睡著了一般。 火紅的嫁衣襯著肌膚如雪计雌。 梳的紋絲不亂的頭發(fā)上悄晃,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天玫霎,我揣著相機與錄音凿滤,去河邊找鬼。 笑死庶近,一個胖子當著我的面吹牛翁脆,可吹牛的內容都是我干的。 我是一名探鬼主播鼻种,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼反番,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起罢缸,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤篙贸,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后枫疆,有當地人在樹林里發(fā)現了一具尸體爵川,經...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年息楔,在試婚紗的時候發(fā)現自己被綠了寝贡。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡值依,死狀恐怖圃泡,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情愿险,我是刑警寧澤颇蜡,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站辆亏,受9級特大地震影響澡匪,放射性物質發(fā)生泄漏。R本人自食惡果不足惜褒链,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一唁情、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧甫匹,春花似錦甸鸟、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至恍箭,卻和暖如春刻恭,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背扯夭。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工鳍贾, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人交洗。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓骑科,卻偏偏與公主長得像,于是被迫代替她去往敵國和親构拳。 傳聞我的和親對象是個殘疾皇子咆爽,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345

推薦閱讀更多精彩內容