2017-02-15 5 views
0

、私はdispatch_asyncを使用しています、私はiOSデベロッパとしてスウィフトに取り組んでいると私は、非同期の方法でサブビューを追加し、最近いくつかの問題を抱えている(dispatch_get_main_queue()を追加されていませんが、それでも、それはしていませんサブビューは1つずつ追加されていませんし、リアルタイムではありますが、コールが完了するまでUIを更新するまで待つ必要があります。私の目標は、サブビューを1つずつ追加して、forループをまだ行く。以下は、私のコードの一部です。誰かが、私はそれを本当に感謝私を助けることができる場合。ビューは、非同期スウィフトサブビュー

for i in 0 ..< self.allChannels.count { 
     let param = Params().getEpgParams(String(self.allChannels[i].channelNumber))  
     uNetwork().httpRequestNoLoading(self.utilityClass.currentServer , parameters: param, method: uNetwork.METHOD.POST, parent: self) { (epgResponse, extra_information) ->() in 

      if(extra_information != uNetwork.EXTRA_INFORMATION.SUCCESS){ 
       self.presentViewController(self.utilityClass.alert("Error", message: "An Unexpected Error Happened"), animated: true, completion: nil) 
      } else if(epgResponse == nil){ 
       self.presentViewController(self.utilityClass.alert("Error", message: "Couldn't get any response from the server"), animated: true, completion: nil) 
      } else { 
       do { 
        var titleArray = [String]() 
        var start = [String]() 
        var end = [String]() 
        var progressArray = [Float]() 

        let jsonObject = try NSJSONSerialization.JSONObjectWithData(epgResponse, options: []) as! NSDictionary 
        if let response_object = jsonObject["response_object"] as? [[String: AnyObject]] { 
         for menu in response_object{ 
          titleArray.append(menu["title"] as! String) 
          start.append(menu["programstart"] as! String) 
          end.append(menu["programend"] as! String) 
          progressArray.append(menu["progress"] as! Float) 
         } 



         if(titleArray.count > 0){ 
          currentTitle = titleArray[0] 
          currentStart = start[0][start[0].startIndex.advancedBy(12)..<start[0].startIndex.advancedBy(12+4)] 
          currentEnd = end[0][end[0].startIndex.advancedBy(12)..<end[0].startIndex.advancedBy(12+4)] 
          progressValue = Float(progressArray[0]/100) 
         } else { 
          currentTitle = "Programet e \(self.allChannels[i].title)" 
          currentStart = "00:00" 
          currentEnd = "00:00" 
          progressValue = 0.5 
         } 

          dispatch_async(dispatch_get_main_queue(), { 
          indiSub[i].removeFromSuperview() 

          self.contentView = UIView(frame: CGRectMake(0, ((self.scrollView.frame.height/4) * CGFloat(i)), self.epgView.frame.width, self.scrollView.frame.height/4)) 
          self.contentView.layer.masksToBounds = true 
          self.scrollView.addSubview(self.contentView) 

          let button = UIButton(frame: CGRectMake(0, ((self.scrollView.frame.height/4) * CGFloat(i)), self.epgView.frame.width, self.scrollView.frame.height/4)) 
          button.tag = Int(self.allChannels[i].channelNumber) 
          button.addTarget(self, action: #selector(LiveTvTest.playFromEpg(_:)), forControlEvents: .TouchUpInside) 
          self.scrollView.addSubview(button) 

          let currentTime = UILabel(frame: CGRectMake((self.scrollView.frame.height/4) + 25, 0, 60, self.contentView.frame.height/3)) 
          if currentStart.characters.count == 4{ 
           currentTime.text = currentStart + "  |" 
          } else if (currentStart.characters.count == 5){ 
           currentTime.text = currentStart + " |" 
          } 
          currentTime.font = UIFont(name: "Helvetica Neue", size: 15) 
          currentTime.adjustsFontSizeToFitWidth = true 
          currentTime.textColor = UIColor(red:0.54, green:0.13, blue:0.13, alpha:1.0) 
          self.contentView.addSubview(currentTime) 

          let nextTime = UILabel(frame: CGRectMake((self.scrollView.frame.height/4) + 25, currentTime.frame.height, 60, self.contentView.frame.height/3)) 
          if nextStart.characters.count == 4{ 
           nextTime.text = nextStart + "  |" 
          } else if (nextStart.characters.count == 5) { 
           nextTime.text = nextStart + " |" 
          } 
          nextTime.font = UIFont(name: "Helvetica Neue", size: 15) 
          nextTime.adjustsFontSizeToFitWidth = true 
          nextTime.textColor = UIColor(red:0.53, green:0.53, blue:0.53, alpha:1.0) 
          self.contentView.addSubview(nextTime) 
          }) 


        } else { 
         print("something went wrong with response object") 
        } 




       } catch { 
        self.presentViewController(self.utilityClass.alert("Error", message: "Something went wrong, please try again later"), animated: true, completion: nil) 
       } 
      } 
     } 
    } 

答えて

0

あなたの閉鎖は(あなたがhttpRequestNoLoadingに手渡すこと)runniであることを確認することができた場合任意のスレッドでは、dispatch_syncをUIのメインスレッドに更新することができます。これは、作業項目が実行されるまで待機します。しかし、もしそのクローズがすでにメインスレッドで実行されていれば、これは確実にデッドロックになります。

Btw。また、presentViewController呼び出しをメインスレッドにディスパッチする必要があります。

0

私は、あなたがhttpコールのセットを設定していることが問題だと思います。これらの呼び出しは並行して実行され、コールバックを介して戻ります。いくつかのビューの更新を非常に密接にしているので、たとえコードがシリアルであっても、更新はすばやく連続して起こります。

これは、osx/iosがUiの更新を一括して行うということです。一度にmainQueueでかなりの作業をしている可能性があり、作業が行われるのを見る機会が得られていない可能性があります。 dispatch_afterを使っていくつかのランダムな遅延を追加してみて、違うタイミングでポップインするのを見てみましょう。