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

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

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

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

Xcode

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

Swift

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

Q&A

解決済

2回答

3874閲覧

UserDefaultsで保存したTextFieldの入力内容が消えてしまう

hik_

総合スコア42

iOS

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

Xcode

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

Swift

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

0グッド

0クリップ

投稿2019/02/17 10:47

編集2019/02/25 14:08

前提・実現したいこと

TextFieldに入力した数字をaTextに足した数をLabelに表示する機能を作っていて、アプリを再起動すると消えてしまうのでUserDefautlsを使って実装したいのですが、Labelに表示する所までは出来たのですがアプリをマルチタスクで上にスワイプして終了すると、UserDefaultsで保存していた内容が消えてしまいます。
イメージ説明

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

またTextFieldに何も入力せずにOKを押すと以下のエラーが出てしまいます。
エラーを調べているのですが今現在解決出来ていない現状です。

import UIKit var aText:Int = 0 class addViewController: UIViewController { @IBOutlet weak var textField: UITextField! override func viewDidLoad() { super.viewDidLoad() // textFieldの入力方法をナンバーパッドに設定 textField.keyboardType = UIKeyboardType.numberPad } @IBAction func okButton(_ sender: Any) { let textB = Int(textField.text!) aText = aText + textB! // Thread 1: Fatal error: Unexpectedly found nil while unwrapping an Optional value UserDefaults.standard.set(String(aText), forKey: "textKey") } }

該当のソースコード

import UIKit class ViewController: UIViewController { @IBOutlet weak var label: UILabel! override func viewDidLoad() { super.viewDidLoad() } override func viewDidAppear(_ animated: Bool) { super.viewDidAppear(animated) if let _ = UserDefaults.standard.object(forKey: "textKey") as? String { label.text = (UserDefaults.standard.object(forKey: "textKey") as! String) } } }
import UIKit var aText:Int = 0 class addViewController: UIViewController { @IBOutlet weak var textField: UITextField! override func viewDidLoad() { super.viewDidLoad() // textFieldの入力方法をナンバーパッドに設定 textField.keyboardType = UIKeyboardType.numberPad } @IBAction func okButton(_ sender: Any) { let textB = Int(textField.text!) aText = aText + textB! UserDefaults.standard.set(String(aText), forKey: "textKey") } }

2/25追記

import UIKit var aText:Int = 0 class addViewController: UIViewController { @IBOutlet weak var textField: UITextField! override func viewDidLoad() { super.viewDidLoad() // textFieldの入力方法をナンバーパッドに設定 textField.keyboardType = UIKeyboardType.numberPad } override func viewDidAppear(_ animated: Bool) { super.viewDidAppear(animated) if let _ = UserDefaults.standard.object(forKey: "textKey") as? Int { aText = (UserDefaults.standard.object(forKey: "textKey") as! Int) } } @IBAction func addButton(_ sender: Any) { let textB = Int(textField.text!) aText = aText + textB! UserDefaults.standard.set(String(aText), forKey: "textKey") } }
import UIKit class ViewController: UIViewController { @IBOutlet weak var label: UILabel! override func viewDidLoad() { super.viewDidLoad() } override func viewDidAppear(_ animated: Bool) { super.viewDidAppear(animated) if let _ = UserDefaults.standard.object(forKey: "textKey") as? String { label.text = (UserDefaults.standard.object(forKey: "textKey") as! String) } } }

試したこと

エラーとUserDefaultsを調べて、上記のコードを書いたのですが今現在解決はしていない状況です。
ご教示頂けると幸いです。
宜しくお願いします。

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

Swift4 Xcode10

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

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

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

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

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

guest

回答2

0

UserDefaults.standard.set(String(aText), forKey: "textKey")
の後に
UserDefaults.standard.synchronize()
を明示的に呼ぶとどうですか?

たしか現在はsynchronize()の利用は非推奨だった気がしますが、UserDefaults自体はsetしてもメモリの中に格納されるだけで、それがどこかのタイミングで自動的にストレージに保存されていたはずです。
これを明示的に保存するのがsynchronize()です。

自動保存が仮に何らかの原因でうまく動いていないのでしら、これで保存が行われるかなと思います。

※仮にこれで解決したとしても、そのまま作り込むのはあまりおすすめしませんが、とりあえず検証してみてもらえますでしょうか。

投稿2019/02/25 01:12

takabosoft

総合スコア8356

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

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

fuzzball

2019/02/25 01:15 編集

非推奨ではなく不要(unnecessary)ということなので、 >>メモリの中に格納されるだけで この辺の仕組みが変わったんじゃないでしょうかね。
takabosoft

2019/02/25 01:17

むしろ「shouldn't be used.(使うな)」って書いてありますね(^_^;) まあお試しって事で・・・
hik_

2019/02/25 13:29 編集

ご返信ありがとうございます。新しくプロジェクトを作成して、同じようにコードを書いたりしていて、synchronize()を追加する前にシミュレーターを立ち上げてみたら、自分自身どう解決したのかは分からないのですが、再起動をしても値が表示されるようになりました。 ありがとうございます。 なのですが、再起動するとLabelにUserDefaultsで保存した値が表示されるのですが、addViewControllerのTextFieldに数字を入力した数をViewControllerのLabelに表示されている数字に足して、表示したいのですが、再起動するとUserDefaultsで保存された値はLabelに表示されるのですが、TextFieldに入力してOKを押したら、UserDefaultsに保存されていてLabelに表示されたいた値がリセットされて新たにTextFieldに入力した値に変わってしまいます。 ご返信お待ちしております。宜しくお願いします。
hik_

2019/02/25 14:12

現在UserDefaultsについて調べていて、コードを書いて試している状況ですが、改善していない状態です。 質問に追記として調べて色々と修正してみている状況ですが、現状でのコードを記載しました。 宜しくお願いします。
takabosoft

2019/02/26 00:55

消える件が解消したのでしたら、一旦質問はクローズして新たに質問を立ててください。キリがありませんので。
hik_

2019/02/26 02:39

ご返信ありがとうございます。 一度質問をクローズした後、再度質問させて頂きます。 ありがとうございました。
guest

0

ベストアンサー

エラーとUserDefaultsを調べて

問題がある場合、可能な限りシンプルな形にして問題がどこにあるのかを把握するようにした方が良いです。エラーがあるのであれば、エラーだけを取り除くようにし、UserDefaultsが期待通り動作しないということであれば、UserDefaultsだけの確認を行うようにすべきでしょう。

エラーについて

文字列から整数型に変換するIntはoptional型になります。

let textB = Int(textField.text!)
この場合、textB
で、次のコードでそれを剥がそうとしていますが、エラーメッセージの通りなので剥がせないと怒っています。
aText = aText + textB! // Thread 1: Fatal error: Unexpectedly found nil while unwrapping an Optional value

Optional型をきちんとはがすようにしましょう。

swift

1guard let iB = Int(textField.text!) else { 2 return 3} 4aText = aText + iB

投稿2019/02/18 02:05

t_obara

総合スコア5488

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

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

hik_

2019/02/21 05:29

ご返信ありがとうございます。実装してみます。
hik_

2019/02/23 07:57

ご回答の通り実装した所エラーが解消しました。ありがとうございます。 現在UserDefaultsの問題について調べているのですが、まだ解決していない状況です。 質問内に記載しているコードに不足や間違いなどがありましたら、 ご教示頂けると幸いです。宜しくお願いします。
t_obara

2019/02/25 00:59

どのように修正し、その結果どのような状況なのかをお示しください。
hik_

2019/02/25 23:50 編集

ご返信ありがとうございます。 修正は出来ていないのですが、色々とUserDefaultsのインスタンスやデリゲートなど改めて調べていた状況です。 また再起動後の保存に関しては再起動しても表示されるようになり解決しました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問