🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

例外

例外(exception)とは、プログラムの処理実行中に発生する、通常の処理の続行を妨げる特殊な事象のことを呼びます。この「例外」が発生した場合に、現在の処理を中断し、変わりに別の処理を実行させる事を「例外処理」と呼びます。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

1回答

959閲覧

swift apple watch 「libc++abi.dylib: terminating with uncaught exception of type NSException」について

AppDvl

総合スコア58

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

例外

例外(exception)とは、プログラムの処理実行中に発生する、通常の処理の続行を妨げる特殊な事象のことを呼びます。この「例外」が発生した場合に、現在の処理を中断し、変わりに別の処理を実行させる事を「例外処理」と呼びます。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2019/09/29 10:42

編集2019/09/30 08:17

◎わからないこと
apple watch で心拍数を図るアプリを作りたいので下記のようにコードを記述しましたが、libc++abi.dylib: terminating with uncaught exception of type NSExceptionのエラーが出てします。
修正したいがどうすればよいか分からない。
◎試したこと
1,Interface.storyboardで@IBOutletとのリンクを切って再接続したが状況は変わらない。重複もない。
2,ブレークポイントで確認したら下記の箇所が怪しい。

// アクセス許可をユーザに求める let dataTypes = Set([self.heartRateType]) self.healthStore.requestAuthorization(toShare: nil, read: dataTypes) { (success, error) -> Void in guard success else { self.label.setText("not allowed") return } }

◎エラー文

libc++abi.dylib: terminating with uncaught exception of type NSException (lldb)

イメージ説明

◎すべてのコード

import WatchKit import Foundation import HealthKit import WatchConnectivity class InterfaceController: WKInterfaceController { // @IBOutlet var label: WKInterfaceLabel! // @IBOutlet var messageLabel: WKInterfaceLabel! // @IBOutlet var button: WKInterfaceButton! // @IBOutlet var secondbutton: WKInterfaceButton! @IBOutlet weak var label: WKInterfaceLabel! @IBOutlet weak var messageLabel: WKInterfaceLabel! @IBOutlet weak var button: WKInterfaceButton! @IBOutlet weak var secondbutton: WKInterfaceButton! // HealthKitで扱うデータを管理するクラス(データの読み書きにはユーザの許可が必要) let healthStore = HKHealthStore() // 取得したいデータの識別子、今回は心拍数 let heartRateType = HKQuantityType.quantityType(forIdentifier: HKQuantityTypeIdentifier.heartRate)! // 取得したデータの単位、今回はBPM let heartRateUnit = HKUnit(from: "count/min") // HealthStoreへのクエリ //HealthKitのすべてのクエリクラスの抽象クラス var heartRateQuery: HKQuery? //iphoneと通信 var wcSession = WCSession.default override func awake(withContext context: Any?) { super.awake(withContext: context) // check supported if WCSession.isSupported() { // get default session wcSession = WCSession.default // set delegate wcSession.delegate = self as? WCSessionDelegate // activate session wcSession.activate() } else { print("Not support WCSession") } // iPhoneとAppleWatchの連携チェック if WCSession.isSupported() { wcSession.delegate = self as? WCSessionDelegate wcSession.activate() } // Configure interface objects here. } override func willActivate() { // This method is called when watch view controller is about to be visible to user super.willActivate() // HealthKitがデバイス上で利用できるか確認 guard HKHealthStore.isHealthDataAvailable() else { self.label.setText("not available") return } // アクセス許可をユーザに求める let dataTypes = Set([self.heartRateType]) self.healthStore.requestAuthorization(toShare: nil, read: dataTypes) { (success, error) -> Void in guard success else { self.label.setText("not allowed") return } } } // healthStoreへのクエリ生成 private func createStreamingQuery() -> HKQuery { let predicate = HKQuery.predicateForSamples(withStart: NSDate() as Date, end: nil, options: []) // HKAnchoredObjectQueryだと他のアプリケーションによる更新を検知 let query = HKAnchoredObjectQuery(type: heartRateType, predicate: predicate, anchor: nil, limit: Int(HKObjectQueryNoLimit)) { (query, samples, deletedObjects, anchor, error) -> Void in self.addSamples(samples: samples) } query.updateHandler = { (query, samples, deletedObjects, anchor, error) -> Void in self.addSamples(samples: samples) } return query } // 取得したデータを表示,保存 private func addSamples(samples: [HKSample]?){ guard let samples = samples as? [HKQuantitySample] else { return } guard let quantity = samples.last?.quantity else { return } let hartrate = (quantity.doubleValue(for: heartRateUnit)) label.setText("(hartrate)") print(hartrate) let file_name = "test_HR.txt" let text = "(hartrate)" let path = NSHomeDirectory() + "/Documents/(file_name)" print("(path)") do{ try text.write(toFile: path, atomically: true, encoding: String.Encoding.utf8) print("書き込み成功") }catch{ print("失敗") //print(message) } } @IBAction func buttonTapped() { if self.heartRateQuery == nil { // start // クエリ生成 self.heartRateQuery = self.createStreamingQuery() // クエリ実行 self.healthStore.execute(self.heartRateQuery!) self.button.setTitle("Stop") self.messageLabel.setText("Measuring...") } else { // end self.healthStore.stop(self.heartRateQuery!) self.heartRateQuery = nil self.button.setTitle("Start") self.messageLabel.setText("") } } override func didDeactivate() { // This method is called when watch view controller is no longer visible super.didDeactivate() } }

reasonの箇所

2019-09-30 16:54:40.412248+0900 RepMonitor WatchKit Extension[952:12172] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: 'The string "Save the data" is an invalid value for NSHealthShareUsageDescription' 28 UIKitCore 0x5e24e466 -[UIApplication _stopDeactivatingForReason:] + 1106 32 UIKitCore 0x5da30b37 -[_UISceneLifecycleMultiplexer _performBlock:withApplicationOfDeactivationReasons:fromReasons:] + 468 (lldb)

イメージ説明

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

thyda.eiqau

2019/09/30 00:40

エラーの原因を特定するための情報が提示されていないので回答のしようがないです。Exceptionの内容がコンソールに記載されているはずなのでコピペして提示してください。Reasonという単語が出てくる付近です。 あとその画像は先に進みすぎていてどこで止まっているのか分からないので、Breakpointの設定ペインの左下だか右下だかのプラス記号からAll Exceptionに対するBreakpointを追加して、止まったところの画像を提供してください。
AppDvl

2019/09/30 08:14

thyda.eiqauさん コンソールの全文は文字数の制限で記載できないので「Reason」を検索して、該当箇所を記載しました。 あと『あとその画像は先に進みすぎていてどこで止まっているのか分からないので、Breakpointの設定ペインの左下だか右下だかのプラス記号からAll Exceptionに対するBreakpointを追加して、止まったところの画像を提供してください。』とのことですが、どのボタンのことかわからないので私のxcodeの画面を載せます。赤丸のプラスマークのことでしょうか?
thyda.eiqau

2019/09/30 08:22

> The string "Save the data" is an invalid value for NSHealthShareUsageDescription とのことなので、 info.plist の NSHealthShareUsageDescription (Privacy - Health Share Usage Description) の値を見直してみてはいかがでしょうか。すべてのロケールで12文字以上である必要があると言っている人もいました (Save the dataは13文字あるような気がしますが……) あとブレークポイントは位置は合ってるのですが、その画面ではないです。その赤丸からずらーっと上に行くとフォルダーマークがハイライトされていて虫眼鏡とか注意記号とか吹き出しみたいなボタンが並んでいるところがありますよね。その右から2つ目をクリックしてからその辺に出てくるプラスアイコンを押してください。
AppDvl

2019/10/02 11:27

thyda.eiqauさん info.plistを"Save the HealthData"に変えたら上手く行きました。 ブレークポイントを初めて今回つかってまた知識が増えた気がします(結果的に役に立ちませんでしたが) これからはエラーメッセージを理解するよう努めます。ありがとうございました。
AppDvl

2019/10/02 11:31

thyda.eiqauさん この欄は”質問への追記、修正依頼”なので評価が出来ないようです。 解答欄に何かコメントいただければ「ベストアンサー」をつけたいと思いますのでよろしくおねがいします。
guest

回答1

0

自己解決

info.plist の文字数が足りなかった。

投稿2019/10/06 01:22

AppDvl

総合スコア58

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問