onSavedInstanceState vs. SharedPreferences

你离开我真会死。 提交于 2019-12-18 05:00:10

问题


I have 7 activites all with back and forth navigation buttons between the rest; activites consist of editTexts, Spinners, textViews, TimePickers, DatePickers, and checkboxes.

I want all UI to be present and saved through navigation of an application instance; however on application termination everything needs to default.

My 8th activity collects all UI and places into an email . . .fyi

I have read alot about both onSavedInstanceState & SharedPreferences way of saving the data as activities go back and forth . . .

Which would be better for me?


回答1:


It will depend on how you want to manage the data. Both options (and more) are feasible:

  • If you want to fill once and keep the data even if the app gets killed, use SharedPreferences.
  • If it's volatile data that will have to be reentered differently some other time (i.e., days later), then use onSavedInstanceState.
  • If you want to keep multiple datasets on the same device, then use a SQLiteDatabase



回答2:


SharedPreferences

  • Use for things that should always be remembered, no matter if the phone is turned off (eg for settings chosen in the settings screen of your app

onSavedInstanceState

  • Use this for remembering things about the current state of your activity such as the currently selected tab on the screen. This allows you to recreate the same state after a rotation or if the app was killed due to low memory.
  • The things saved in onSaveInstanceState will be forgotten after reboot, and when starting a new instance of an activity they will not be passed, so they are only for remembering the state of the activity

onRetainNonConfigurationInstance

  • Use this for storing objects which take a long time to load so that you don't have to load them again when the phone is rotated.


来源:https://stackoverflow.com/questions/5901482/onsavedinstancestate-vs-sharedpreferences

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!