UITableView崩溃在tableview.datasource开始

问题描述:

我已经在单独的ViewController类中实现了两个UITableview。在成功添加第二个UItableView的代码后,我的项目会生成,但加载后会停止。UITableView崩溃在tableview.datasource开始

它停止了红线:

tableView.delegate.dataSource = self 

随着读取错误:

Thread 1 EXEC_BAD_INSTRUCTION (code-EXC_i386_INVOP,subcode=0x0)

fatal error: unexpectedly found nil while unwrapping an Optional value

因为这并没有发生,直到将第二在第二个视图控制器中的UItableview我想知道如果我的代码可能彼此冲突。我将发布两个视图控制器的副本。我应该改变什么?

顺便说一句:FilmsViewController是应用程序崩溃的地方。虽然它的工作将MCViewController电影之前:

B:

class FilmsViewController: UIViewController, UITableViewDataSource, UITableViewDelegate { 
    weak var tableView : UITableView! 
    var FilmArray = [String]() 

    let film_url = "https://www.testing.com/api/resources/films/1" 
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
     return FilmArray.count 
    } 
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 


     let cell = tableView.dequeueReusableCell(withIdentifier: "mycell", for:indexPath) as! FilmsAPITableViewCell 
     // Configuring Cell 
     cell.movieTitle.text = FilmArray[indexPath.row] 
     // Returning the cell 
     return cell 
    } 
    override func viewDidLoad() { 
     super.viewDidLoad() 

     tableView.dataSource = self 
     tableView.delegate = self 
     let url:URL = URL(string: film_url)! 
     let session = URLSession.shared 

     let request = NSMutableURLRequest(url: url) 
     request.httpMethod = "GET" 
     request.setValue("740c94c51891c02b64d6c78840b478fe0b02fe2c", forHTTPHeaderField: "X-API-KEY") 
     request.setValue("Basic YmhlZW0uZW5nckBnbWFpbC5jb206YmgzM20=", forHTTPHeaderField: "Authorization") 
     request.cachePolicy = NSURLRequest.CachePolicy.reloadIgnoringCacheData 
     let paramString = "" 

     request.httpBody = paramString.data(using: String.Encoding.utf8) 

     let task = session.dataTask(with: request as URLRequest, completionHandler: { 
      (
      data, response, error) in 

      guard let _:Data = data, let _:URLResponse = response , error == nil else { 

       return 
      } 



      var json:Any? 

      do 
      { 
       if let existingData = data { 
        json = try JSONSerialization.jsonObject(with: existingData, options: []) 
       } 

       // Prasing JSON 
       if let parsedData = json as? [[String:Any]] { 
        for dict in parsedData { 
         if let title = dict["title"] as? String { 
          self.FilmArray.append(title) 
          print(json) 
         } 
        } 

        OperationQueue.main.addOperation({ 
         self.tableView.reloadData() 
        }) 
       } 
      } 
      catch 
      { 
       return 
      } 

      guard let server_response = json as? NSDictionary else 
      { 
       return 
      } 

      if let data_block = server_response["data"] as? NSDictionary 
      { 
       if let session_data = data_block["session"] as? String 
       { 
        // self.login_session = session_data 

        let preferences = UserDefaults.standard 
        preferences.set(session_data, forKey: "session") 

        // DispatchQueue.main.async(execute: self.LoginDone) 
       } 
      } 
     }) 

     task.resume() 

     // Do any additional setup after loading the view. 
    } 

    override func didReceiveMemoryWarning() { 
     super.didReceiveMemoryWarning() 
     // Dispose of any resources that can be recreated. 
    } 



} 

MC:

class MCViewController: UIViewController, UITableViewDataSource, UITableViewDelegate { 

    let message_url = "https://www.testing.com/api/resources/get_film_message/film_id/3825" 
    let send_url = "https://www.testing.com/api/resources/send_film_message" 
    let film_id = "3825" 
    var messageArray = [String]() 
    weak var tableView : UITableView! 

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
     return messageArray.count 
    } 
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 


     let cell = tableView.dequeueReusableCell(withIdentifier: "msgContent", for:indexPath) as! MessageTableViewCell 
     // Configuring Cell 
     cell.msgContent.text = messageArray[indexPath.row] 
     // Returning the cell 
     return cell 
    } 



    @IBOutlet weak var MessageInput: UITextField! 
    @IBAction func Sendmsg(_ sender: Any) { 
     Sendmsg(username:MessageInput.text!, password: film_id) 
    } 

    override func viewDidLoad() { 
     super.viewDidLoad() 

     tableView.dataSource = self 
     tableView.delegate = self 
     // Do any additional setup after loading the view. 
     //let post_data: NSDictionary = NSMutableDictionary() 


     //  post_data.setValue(username, forKey: "username") 
     //  post_data.setValue(password, forKey: "password") 

     let url:URL = URL(string: message_url)! 
     let session = URLSession.shared 

     let request = NSMutableURLRequest(url: url) 
     request.httpMethod = "GET" 
     request.setValue("740c94c51891c02b64d6c78840b478fe0b02fe2c", forHTTPHeaderField: "X-API-KEY") 
     request.setValue("Basic YmhlZW0uZW5nckBnbWFpbC5jb206YmgzM20=", forHTTPHeaderField: "Authorization") 
     request.cachePolicy = NSURLRequest.CachePolicy.reloadIgnoringCacheData 
     // Do any additional setup after loading the view. 
     var paramString = "" 


     //  for (key, value) in post_data 
     //  { 
     //   paramString = paramString + (key as! String) + "=" + (value as! String) + "&" 
     //  } 
     // 
     request.httpBody = paramString.data(using: String.Encoding.utf8) 

     let task = session.dataTask(with: request as URLRequest, completionHandler: { 
      (
      data, response, error) in 

      guard let _:Data = data, let _:URLResponse = response , error == nil else { 

       return 
      } 



      let json: Any? 

      do 
      { 
       json = try JSONSerialization.jsonObject(with: data!, options: []) 
       if let parsedData = json as? [[String:Any]] { 
        for dict in parsedData { 
         if let title = dict["message"] as? String { 
          self.messageArray.append(title) 
          print(json) 
         } 
        } 
       } 
      } 
      catch 
      { 
       return 
      } 

      guard let server_response = json as? NSDictionary else 
      { 
       return 
      } 


      if let data_block = server_response["data"] as? NSDictionary 
      { 
       if let session_data = data_block["session"] as? String 
       { 
        // self.login_session = session_data 

        let preferences = UserDefaults.standard 
        preferences.set(session_data, forKey: "session") 

        // DispatchQueue.main.async(execute: self.LoginDone) 
       } 
      } 



     }) 

     task.resume() 
    } 

    override func didReceiveMemoryWarning() { 
     super.didReceiveMemoryWarning() 
     // Dispose of any resources that can be recreated. 
    } 

    func Sendmsg(username:String, password:String) 
    { 
     let post_data: NSDictionary = NSMutableDictionary() 


     post_data.setValue(username, forKey: "message") 
     post_data.setValue(password, forKey: "film_id") 

     let url:URL = URL(string: send_url)! 
     let session = URLSession.shared 

     let request = NSMutableURLRequest(url: url) 
     request.httpMethod = "POST" 
     request.setValue("740c94c51891c02b64d6c78840b478fe0b02fe2c", forHTTPHeaderField: "X-API-KEY") 
     request.setValue("Basic YmhlZW0uZW5nckBnbWFpbC5jb206YmgzM20=", forHTTPHeaderField: "Authorization") 
     request.cachePolicy = NSURLRequest.CachePolicy.reloadIgnoringCacheData 

     var paramString = "" 


     for (key, value) in post_data 
     { 
      paramString = paramString + (key as! String) + "=" + (value as! String) + "&" 
     } 

     request.httpBody = paramString.data(using: String.Encoding.utf8) 

     let task = session.dataTask(with: request as URLRequest, completionHandler: { 
      (
      data, response, error) in 

      guard let _:Data = data, let _:URLResponse = response , error == nil else { 

       return 
      } 



      let json: Any? 

      do 
      { 
       json = try JSONSerialization.jsonObject(with: data!, options: []) 
       print(json) 
      } 
      catch 
      { 
       return 
      } 

      guard let server_response = json as? NSDictionary else 
      { 
       return 
      } 


//   if let data_block = server_response["data"] as? NSDictionary 
//   { 
//    if let session_data = data_block["session"] as? String 
//    { 
//     self.login_session = session_data 
//      
//     let preferences = UserDefaults.standard 
//     preferences.set(session_data, forKey: "session") 
//      
//     DispatchQueue.main.async(execute: self.LoginDone) 
//    } 
//   } 
//    


     }) 

     task.resume() 


    } 


    /* 
    // MARK: - Navigation 

    // In a storyboard-based application, you will often want to do a little preparation before navigation 
    override func prepare(for segue: UIStoryboardSegue, sender: Any?) { 
    // Get the new view controller using segue.destinationViewController. 
    // Pass the selected object to the new view controller. 
    } 
    */ 

} 

你在哪里初始化tableView?好像它可能是nil ....

tableView = UITableView(frame: frame)

如果你使用的情节提要/厦门国际银行,你还可以连接tableView了作为IBOutlet

+0

tableView = UITableView(frame:frame)?我不确定我在呼唤它。你能多解释一下吗? –

+0

我应该在哪里调用它? –

+0

在做其他事情之前,我会在'viewDidLoad'中调用它。 'frame'参数将是一个CGRect,它具有你想要的x,y位置和宽度,高度。虽然我会小心地根据viewDidLoad中的视图框架来设置框架,因为视图的框架还没有被计算出来。 'viewDidLoad'中的tableView = UITableView()'然后'tableView.frame = CGRect(x:yourX,y:yourY,width:yourWidth,height:yourHeight)''viewDidAppear'中的其他地方也是一个可行的选项。 – Samantha