質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.09%

Tread 1:signal SIGABRTが出てアプリがビルドできない

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 922

前提・実現したいこと

Todoリストを作成しているのですが、セルタップによるタスク編集を実装途中に以下のエラーでビルドができなくなってしまいました。そのエラーを解消したいです。

発生している問題・エラーメッセージ

エラーは以下の部分で表示されています。(AppDelegate.swift)
下はデバック画面になります。

class AppDelegate: UIResponder, UIApplicationDelegate { < Tread 1:signal SIGABRT


2018-12-14 17:21:28.889 TaskControl[6327:955929] *** Assertion failure in -[UITableView dequeueReusableCellWithIdentifier:forIndexPath:], /BuildRoot/Library/Caches/com.apple.xbs/Sources/UIKit_Sim/UIKit-3600.6.21/UITableView.m:6600
2018-12-14 17:21:28.907 TaskControl[6327:955929] *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'unable to dequeue a cell with identifier TaskCell - must register a nib or a class for the identifier or connect a prototype cell in a storyboard'
*** First throw call stack:
(
    0   CoreFoundation                      0x000000010e127d4b __exceptionPreprocess + 171
    1   libobjc.A.dylib                     0x000000010b00121e objc_exception_throw + 48
    2   CoreFoundation                      0x000000010e12be42 +[NSException raise:format:arguments:] + 98
    3   Foundation                          0x000000010ab9666d -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 195
    4   UIKit                               0x000000010ba4c1e8 -[UITableView dequeueReusableCellWithIdentifier:forIndexPath:] + 259
    5   TaskControl                         0x000000010aa03981 _TFC11TaskControl14ViewController9tableViewfTCSo11UITableView12cellForRowAtV10Foundation9IndexPath_CSo15UITableViewCell + 353
    6   TaskControl                         0x000000010aa041e7 _TToFC11TaskControl14ViewController9tableViewfTCSo11UITableView12cellForRowAtV10Foundation9IndexPath_CSo15UITableViewCell + 87
    7   UIKit                               0x000000010ba5f584 -[UITableView _createPreparedCellForGlobalRow:withIndexPath:willDisplay:] + 757
    8   UIKit                               0x000000010ba5f7e2 -[UITableView _createPreparedCellForGlobalRow:willDisplay:] + 74
    9   UIKit                               0x000000010ba332b0 -[UITableView _updateVisibleCellsNow:isRecursive:] + 3295
    10  UIKit                               0x000000010ba68b64 -[UITableView _performWithCachedTraitCollection:] + 110
    11  UIKit                               0x000000010ba4f3be -[UITableView layoutSubviews] + 222
    12  UIKit                               0x000000010b9b6ab8 -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 1237
    13  QuartzCore                          0x0000000110f8fbf8 -[CALayer layoutSublayers] + 146
    14  QuartzCore                          0x0000000110f83440 _ZN2CA5Layer16layout_if_neededEPNS_11TransactionE + 366
    15  QuartzCore                          0x0000000110f832be _ZN2CA5Layer28layout_and_display_if_neededEPNS_11TransactionE + 24
    16  QuartzCore                          0x0000000110f11318 _ZN2CA7Context18commit_transactionEPNS_11TransactionE + 280
    17  QuartzCore                          0x0000000110f3e3ff _ZN2CA11Transaction6commitEv + 475
    18  QuartzCore                          0x0000000110f3ed6f _ZN2CA11Transaction17observer_callbackEP19__CFRunLoopObservermPv + 113
    19  CoreFoundation                      0x000000010e0cc267 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 23
    20  CoreFoundation                      0x000000010e0cc1d7 __CFRunLoopDoObservers + 391
    21  CoreFoundation                      0x000000010e0b08a6 CFRunLoopRunSpecific + 454
    22  UIKit                               0x000000010b8ebaea -[UIApplication _run] + 434
    23  UIKit                               0x000000010b8f1c68 UIApplicationMain + 159
    24  TaskControl                         0x000000010aa0bc0f main + 111
    25  libdyld.dylib                       0x000000010f0d768d start + 1
    26  ???                                 0x0000000000000001 0x0 + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
(lldb) 

該当のソースコード

関係のなさそうなコードは削りました、、

//ViewController

import UIKit
import CoreData

class ViewController: UIViewController , UITableViewDataSource, UITableViewDelegate {

    // MARK: - Properties

    @IBOutlet weak var taskTableView: UITableView!

    var tasks:[Task] = []
    var tasksToShow:[String:[String]] = ["MustDo":[], "WantToDo":[]]
    let taskCategories:[String] = ["MustDo", "WantToDo"]

    private let segueEditTaskViewController = "SegueEditTaskViewController"


    // MARK: - View Life Cycle


    override func viewDidLoad() {
        super.viewDidLoad()
        taskTableView.dataSource = self
        taskTableView.delegate = self
    }

    override func viewWillAppear(_ animated: Bool) {

        getData()


        taskTableView.reloadData()
    }
    // MARK: - Method of Getting data from Core Data

    func getData() {

        let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
        do {

            let fetchRequest: NSFetchRequest<Task> = Task.fetchRequest()
            tasks = try context.fetch(fetchRequest)


            for key in tasksToShow.keys {
                tasksToShow[key] = []
            }

            for task in tasks {
                tasksToShow[task.category!]?.append(task.name!)
            }
        } catch {
            print("Fetching Failed.")
        }
    }

    // MARK: - Table View Data Source


    func numberOfSections(in tableView: UITableView) -> Int {
        return taskCategories.count
    }
    func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
        return taskCategories[section]
    }

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return tasksToShow[taskCategories[section]]!.count
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        guard let cell = taskTableView.dequeueReusableCell(withIdentifier: TaskTableViewCell.reuseIdentifier, for: indexPath) as? TaskTableViewCell else {
            fatalError("Unexpected Index Path")
        }

        let sectionData = tasksToShow[taskCategories[indexPath.section]]
        let cellData = sectionData?[indexPath.row]

        cell.taskLabel.text = "\(cellData!)"

        return cell
    }

    // MARK: - Navigation

    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        guard let destinationViewController = segue.destination as? AddTaskViewController else { return }


        let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
        destinationViewController.context = context
        if let indexPath = taskTableView.indexPathForSelectedRow, segue.identifier == segueEditTaskViewController {

            let editedCategory = taskCategories[indexPath.section]
            let editedName = tasksToShow[editedCategory]?[indexPath.row]

            let fetchRequest: NSFetchRequest<Task> = Task.fetchRequest()
            fetchRequest.predicate = NSPredicate(format: "name = %@ and category = %@", editedName!, editedCategory)

            do {
                let task = try context.fetch(fetchRequest)
                destinationViewController.task = task[0]
            } catch {
                print("Fetching Failed.")
            }
        }
    }
}

//TaskTableViewController

import UIKit

class TaskTableViewCell: UITableViewCell {

    // MARK: - Properties

    static let reuseIdentifier = "TaskCell"

    // MARK: -
    @IBOutlet var taskLabel: UILabel!



    // MARK: - Initialization

    override func awakeFromNib() {
        super.awakeFromNib()
        // Initialization code
    }

    override func setSelected(_ selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state
    }   
}

//AddTaskViewController

import UIKit
class AddTaskViewController: UIViewController {  
    // MARK: - Properties  
    var context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
    var task: Task?  
    @IBOutlet weak var taskTextField: UITextField!  
    @IBOutlet weak var categorySegmentedControl: UISegmentedControl!  
     // MARK: -  
    var taskCategory = "MustDo"
    override func viewDidLoad() {
        super.viewDidLoad()
        if let task = task {
            taskTextField.text = task.name
            taskCategory = task.category!
            switch task.category! {
            case "MustDo":
                categorySegmentedControl.selectedSegmentIndex = 0
            case "WantToDo":
                categorySegmentedControl.selectedSegmentIndex = 1
            default:
                categorySegmentedControl.selectedSegmentIndex = 0     
        }
        }
    }
     // MARK: - Actions of Button

試したこと

すべてコネクトし直し、xcodeの再起動も行いましたが治りませんでした。。。

補足情報(FW/ツールのバージョンなど)

swift 3
xcode 8.2.1

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

 reason: 'unable to dequeue a cell with identifier TaskCell - must register a nib or a class for the identifier or connect a prototype cell in a storyboard'

TaskCellのセルが登録されていないので登録して下さい。

  • そもそも登録されていない
  • 登録しているけどIDが間違っている

など。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/12/15 08:37

    解決いたしました。ありがとうございます!

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.09%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る