2016-03-17 1 views
0

J'essaye d'implémenter des données de chargement à partir du serveur d'analyse après avoir appuyé sur un bouton sur postVC pour charger des données et naviguer vers guestVC. Ça fonctionnait bien et à un moment donné a commencé à planter l'application ... pas sûr pourquoi? Je reçois l'erreur fatale: inattendue trouvé tout en déballant une valeur facultative ... Toute direction ou aide serait grandement appréciée. Merci!trouvé de manière inattendue nil tout en déballant une valeur facultative dispatch-async

import UIKit 
import Parse 

var postuuid = [String]() 

class postVC: UITableViewController { 

//postVC button click function 
//clicked username button from post 
    @IBAction func usernameBtn_click(sender: AnyObject) { 
     let i = sender.layer.valueForKey("index") as! NSIndexPath 
     let cell = tableView.cellForRowAtIndexPath(i) as! postCell 

     // if user tapped on himself go home, else go guest 
     if cell.usernameBtn.titleLabel?.text == PFUser.currentUser()?.username { 
      let home = self.storyboard?.instantiateViewControllerWithIdentifier("homeVC") as! homeVC 
      self.navigationController?.pushViewController(home, animated: true)  
     } else { 
      let guest = self.storyboard?.instantiateViewControllerWithIdentifier("guestVC") as! guestVC 
      self.navigationController?.pushViewController(guest, animated: true) 
     } 
    } 



// guestVC relevant code 
import UIKit 
import Parse 

var guestname = [String]() 

class guestVC: UICollectionViewController { 

    var uuidArray = [String]() 
    var picArray = [PFFile]() 

    // posts loading function 
    func loadPosts() {  

      let query = PFQuery(className: "posts") 
// app keeps crashing in line below when I try to load data to guestVC 
      query.whereKey("username", equalTo: guestname.last!) 
      query.limit = self.page 
      query.findObjectsInBackgroundWithBlock({ (objects:[PFObject]?, error:NSError?) -> Void in 

       if error == nil { 

        self.uuidArray.removeAll(keepCapacity: false) 
        self.picArray.removeAll(keepCapacity: false) 

        for object in objects! { 
         self.uuidArray.append(object.valueForKey("uuid") as! String) 
         self.picArray.append(object.valueForKey("pic") as! PFFile) 
        } 

        self.collectionView?.reloadData() 
       } else { 
        print(error!.localizedDescription) 
       } 
       dispatch_async(dispatch_get_main_queue(), {() -> Void in 

        // code here will be executed as the main queue 

       }) 
      }) 

    } 

Répondre

0

Vous utilisez beaucoup de points d'exclamation pour forcer le déballage des valeurs facultatives dans votre code, c'est une mauvaise habitude. Par exemple, vous pouvez dérouler guestname.last en toute sécurité par:

guard let lastItem = guestname.last else { 
// do something else 
return 
} 
query.whereKey("username", equalTo: lastItem) 
+0

Ok, merci. Alors qu'est-ce que je retourne dans l'autre déclaration? J'ai quelques instances qui obtiennent des erreurs lorsque je renvoie une requête en utilisant guestname.last lorsque je consulte le guestVC. – user3708224

+0

L'application se bloque car guestname.las est nul (guestname est vide) mais vous essayez de le déplier. Dans l'autre, vous pouvez gérer le cas lorsque guestname est vide (peut-être afficher une erreur dans une vue d'alerte) –

0

Avant d'ajouter ou d'ajouter, vérifiez que la clé du dictionnaire a une valeur valide ou non. Vérifiez si la clé 'uuid' ou 'pic' a une valeur dans le dictionnaire ou non. S'il a alors ajouter/ajouter.