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

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

新規登録して質問してみよう
ただいま回答率
85.47%
Swift

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

Q&A

解決済

2回答

2507閲覧

Swift関数内でreturnを返すときに全ての処理が終わる前に返してしまう。

退会済みユーザー

退会済みユーザー

総合スコア0

Swift

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

0グッド

0クリップ

投稿2018/02/09 06:25

前提・実現したいこと

通知許可設定をすでに選択しているかどうかを判定してBoolで返す関数をつくりたいと思っています。

今回に限らず、関数内でreturnするときに、その中の処理が全て動く前にreturnされてしまいます。そしてその解決方法がわからないままでいました。

今回のような、関数内の処理が全て終わってからreturnをしたい場合にどのようにすれば良いのかご教授いただけますと嬉しいです。

よろしくお願いします。

今回のソースコード

swift

1 static func isNotificationSelected() -> Bool { 2 3 var result = Bool() 4 5 UNUserNotificationCenter.current().getNotificationSettings { (settings) in 6 7 switch settings.authorizationStatus { 8 case .authorized: 9 result = true 10 case .denied: 11 result = true 12 case .notDetermined: 13 result = false 14 } 15 } 16 17 return result 18 19 }

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

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

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

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

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

guest

回答2

0

ベストアンサー

コールバック((settings) in以下)の処理は非同期なのでswitch文を通らず関数を抜けちゃいます。
コールバックのブロックを通った後にresultを返却する場合の改修案を紹介しときます。

swift

1 // Swift4 2 3 static func isNotificationSelected() -> Bool { 4 5 var keepAlive = true 6 var result = Bool() 7 8 UNUserNotificationCenter.current().getNotificationSettings { (settings) in 9 10 switch settings.authorizationStatus { 11 case .authorized: 12 result = true 13 case .denied: 14 result = true 15 case .notDetermined: 16 result = false 17 } 18 keepAlive = false 19 } 20 21 let runLoop = RunLoop.current 22 while keepAlive && 23 runLoop.run(mode: RunLoopMode.defaultRunLoopMode, before: NSDate(timeIntervalSinceNow: 0.1) as Date) { 24 } 25 26 return result 27} 28

投稿2018/02/09 07:19

編集2018/02/09 07:21
fromageblanc

総合スコア2724

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

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

fuzzball

2018/02/09 07:23

正直、同期処理化にはマイナス付けたくなるけど我慢しますw
fromageblanc

2018/02/09 07:26

たしかにキレイじゃないんですよねw
退会済みユーザー

退会済みユーザー

2018/02/09 14:30

ありがとうございます。勉強不足で申し訳ありませんでした。
guest

0

考え方が間違っています。

「関数内の処理(get処理)が終わってから(結果を)return」するのではなく、
「関数内の処理(get処理)が終わったら呼び出し元に結果を渡す」ようにして下さい。

「結果を渡す」というのは return のことではありません。
別の方法で渡します。

投稿2018/02/09 06:37

fuzzball

総合スコア16731

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

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

fromageblanc

2018/02/09 07:20

質問者の方はコールバック部分の非同期が認識できていないのかと。。
fuzzball

2018/02/09 07:24

そうなんですけど、そこから始めると面倒臭いんで‥。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問