सेव की गई प्राथमिकता वाली वैल्यू का इस्तेमाल करें Android Jetpack का हिस्सा है.

इस दस्तावेज़ में बताया गया है कि डेटा को सेव और इस्तेमाल कैसे करें Preference वैल्यू जिन्हें सेव किया गया है प्राथमिकता लाइब्रेरी पर क्लिक करें.

पसंद के मुताबिक डेटा सेव करने की सुविधा

इस सेक्शन में बताया गया है कि Preference, डेटा को कैसे सेव रख सकता है.

शेयर की गई प्राथमिकताएं

डिफ़ॉल्ट रूप से, Preference सेव करने के लिए SharedPreferences वैल्यू. SharedPreferences एपीआई, आसानी से पढ़ने और लिखने की सुविधा देता है सभी ऐप्लिकेशन सेशन में सेव की गई फ़ाइल के की-वैल्यू पेयर. कॉन्टेंट बनाने प्राथमिकता लाइब्रेरी एक निजी SharedPreferences इंस्टेंस का उपयोग करती है, ताकि केवल आपके तो उसे ऐक्सेस कर सकें.

उदाहरण के लिए, मान लें कि SwitchPreferenceCompat:

 <SwitchPreferenceCompat         app:key="notifications"         app:title="Enable message notifications"/> 

जब कोई उपयोगकर्ता इस स्विच को "चालू है" पर टॉगल करता है स्थिति, SharedPreferences फ़ाइल "notifications" : "true" के की-वैल्यू पेयर के साथ अपडेट. इसके लिए, Preference के लिए सेट की गई कुंजी के समान है.

SharedPreferences एपीआई के बारे में ज़्यादा जानकारी के लिए, कुंजी-वैल्यू सेव करना देखें डेटा.

Android पर डेटा सेव करने के अलग-अलग तरीकों के बारे में जानने के लिए, डेटा और फ़ाइल स्टोरेज के बारे में खास जानकारी देखें.

PreferenceDataStore

हालांकि प्राथमिकता लाइब्रेरी में SharedPreferences के साथ डेटा इसके अनुसार मौजूद है डिफ़ॉल्ट रूप से, SharedPreferences हमेशा सही समाधान नहीं होते हैं. उदाहरण के लिए, अगर आपके ऐप्लिकेशन में किसी उपयोगकर्ता को साइन इन करने की ज़रूरत है, तो हो सकता है कि आप जारी रखना जिससे सेटिंग सभी पर दिखाई दे सकें. अन्य डिवाइसों और प्लैटफ़ॉर्म पर काम करता है. इसी तरह, अगर आपके ऐप्लिकेशन में कॉन्फ़िगरेशन खास तौर पर, डिवाइस के हिसाब से विकल्प उपलब्ध होते हैं. डिवाइस पर हर उपयोगकर्ता की अलग-अलग सेटिंग होती हैं, इस वजह से, SharedPreferences एक बेहतर समाधान नहीं है.

PreferenceDataStore Preference की वैल्यू को बनाए रखने के लिए, कस्टम स्टोरेज बैकएंड का इस्तेमाल किया जा सकता है. ज़्यादा के लिए जानकारी के लिए, कस्टम डेटास्टोर का इस्तेमाल करें देखें.

प्राथमिकता मान पढ़ें

इस्तेमाल किए जा रहे SharedPreferences ऑब्जेक्ट को वापस पाने के लिए, कॉल करें PreferenceManager.getDefaultSharedPreferences(). हालांकि यह तरीका आपके ऐप्लिकेशन में कहीं से भी काम करता है, लेकिन हमारा सुझाव है कि अलग-अलग लेयर में बांटा जा सकता है. ज़्यादा जानकारी के लिए, डेटा लेयर.

उदाहरण के लिए, "signature" की कुंजी के साथ EditTextPreference दी गई, जैसे कि अनुसरण करता है:

 <EditTextPreference         app:key="signature"         app:title="Your signature"/> 

इस Preference के लिए सेव की गई वैल्यू को दुनिया भर में वापस लाया जा सकता है. इसके लिए, यह तरीका अपनाएं:

Kotlin

 val sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this /* Activity context */) val name = sharedPreferences.getString("signature", "") 

Java

 SharedPreferences sharedPreferences =         PreferenceManager.getDefaultSharedPreferences(this /* Activity context */); String name = sharedPreferences.getString("signature", ""); 

प्राथमिकता मानों में हुए बदलावों को सुनें

Preference की वैल्यू में हुए बदलावों को सुनने के लिए, इन दो वैल्यू में से किसी एक को चुना जा सकता है इंटरफ़ेस:

नीचे दी गई टेबल में बताया गया है कि दोनों इंटरफ़ेस में क्या अंतर है:

OnPreferenceChangeListener OnSharedPreferenceChangeListener
सिंगल Preference पर सेट है. सभी Preference ऑब्जेक्ट पर लागू होती है.
इसे तब कॉल किया जाता है, जब कोई Preference अपनी सेव की गई वैल्यू को बदलने वाला होता है, भले ही, सेव की गई वैल्यू और सेव की गई वैल्यू एक ही हो. सिर्फ़ तब कॉल किया जाता है, जब Preference के लिए सेव की गई वैल्यू में बदलाव होता है.
सिर्फ़ Preference लाइब्रेरी से कॉल किया गया. डिवाइस का अलग हिस्सा ऐप्लिकेशन के सेव किए गए मान को बदल सकता है. सेव की गई वैल्यू में बदलाव होने पर कॉल किया जाता है, भले ही वह किसी दूसरी वैल्यू से हो ऐप्लिकेशन का हिस्सा है.
'मंज़ूरी बाकी है' वैल्यू सेव होने से पहले कॉल किया जाता है. वैल्यू सेव होने के बाद कॉल किया जाता है.
SharedPreferences या PreferenceDataStore. सिर्फ़ SharedPreferences का इस्तेमाल करने पर कॉल किया गया.

OnPreferenceChangeListener लागू करें

OnPreferenceChangeListener को लागू करने से, 'मंज़ूरी बाकी है' के लिए भी सुना जा सकता है Preference की वैल्यू में बदलाव करना होगा. इसके बाद, यह पुष्टि की जा सकती है कि होता है. उदाहरण के लिए, नीचे दिया गया कोड दिखाता है कि "name" की कुंजी के साथ EditTextPreference की वैल्यू:

Kotlin

 override fun onPreferenceChange(preference: Preference, newValue: Any): Boolean {     Log.e("preference", "Pending Preference value is: $newValue")     return true } 

Java

 @Override public boolean onPreferenceChange(Preference preference, Object newValue) {     Log.e("preference", "Pending Preference value is: " + newValue);     return true; } 

इसके बाद, आपको इस लिसनर को सीधे इसके साथ सेट करना होगा setOnPreferenceChangeListener() इस तरह से:

Kotlin

 preference.onPreferenceChangeListener = ... 

Java

 preference.setOnPreferenceChangeListener(...); 

OnSharedPreferenceChangeListener लागू करें

SharedPreferences का इस्तेमाल करके, Preference वैल्यू को बनाए रखने पर, इनका भी इस्तेमाल किया जा सकता है बदलावों को सुनने के लिए SharedPreferences.OnSharedPreferenceChangeListener. यह आपको Preference से सेव की गई वैल्यू में बदलाव होने पर, सूचना पाने की सुविधा देता है. जैसे कि सर्वर के साथ सेटिंग सिंक करते समय. नीचे दिए गए उदाहरण में, की कुंजी के साथ EditTextPreference के मान में परिवर्तन को सुनने के लिए "name":

Kotlin

 override fun onSharedPreferenceChanged(sharedPreferences: SharedPreferences, key: String) {     if (key == "signature") {         Log.i(TAG, "Preference value was updated to: " + sharedPreferences.getString(key, ""))     } } 

Java

 @Override public void onSharedPreferenceChanged(SharedPreferences sharedPreferences, String key) {     if (key.equals("signature")) {         Log.i(TAG, "Preference value was updated to: " + sharedPreferences.getString(key, ""));     } } 

इसका इस्तेमाल करके लिसनर को रजिस्टर करें registerOnSharedPreferenceChangedListener() इस तरह से:

Kotlin

 preferenceManager.sharedPreferences.registerOnSharedPreferenceChangeListener(...) 

Java

 getPreferenceManager().getSharedPreferences().registerOnSharedPreferenceChangeListener(...); 

Kotlin

     val listener: SharedPreferences.OnSharedPreferenceChangeListener =             SharedPreferences.OnSharedPreferenceChangeListener {...}     

Java

     SharedPreferences.OnSharedPreferenceChangeListener listener =             new SharedPreferences.OnSharedPreferenceChangeListener() {...}     

अपने Activity या Fragment में लाइफ़साइकल मैनेजमेंट के लिए, रजिस्टर करें और जैसा कि दिखाया गया है, onResume() और onPause() कॉलबैक में इस लिसनर का रजिस्ट्रेशन रद्द करें नीचे दिए गए उदाहरण में:

Kotlin

 override fun onResume() {     super.onResume()     preferenceManager.sharedPreferences.registerOnSharedPreferenceChangeListener(this) }  override fun onPause() {     super.onPause()     preferenceManager.sharedPreferences.unregisterOnSharedPreferenceChangeListener(this) } 

Java

 @Override public void onResume() {     super.onResume();     getPreferenceManager().getSharedPreferences().registerOnSharedPreferenceChangeListener(this); }  @Override public void onPause() {     super.onPause();     getPreferenceManager().getSharedPreferences().unregisterOnSharedPreferenceChangeListener(this); } 

कस्टम डेटास्टोर का इस्तेमाल करें

हमारा सुझाव है कि SharedPreferences का इस्तेमाल करके, Preference ऑब्जेक्ट को बनाए रखें, आप कस्टम डेटास्टोर का भी इस्तेमाल कर सकते हैं. कस्टम डेटास्टोर तब फ़ायदेमंद हो सकता है, जब ऐप्लिकेशन किसी डेटाबेस के लिए मान बना रहता है या यदि मान डिवाइस-विशिष्ट हों, जैसे कि नीचे दिए गए उदाहरणों में बताया गया है.

डेटास्टोर लागू करें

कस्टम डेटास्टोर लागू करने के लिए, ऐसी क्लास बनाएं जो PreferenceDataStore. नीचे दिए गए उदाहरण में ऐसा डेटास्टोर बनाया गया है जो String की वैल्यू:

Kotlin

 class DataStore : PreferenceDataStore() {     override fun putString(key: String, value: String?) {         // Save the value somewhere.     }      override fun getString(key: String, defValue: String?): String? {         // Retrieve the value.     } } 

Java

 public class DataStore extends PreferenceDataStore {     @Override     public void putString(String key, @Nullable String value) {         // Save the value somewhere.     }     @Override     @Nullable     public String getString(String key, @Nullable String defValue) {         // Retrieve the value.     } } 

उपयोगकर्ता को ब्लॉक होने से बचाने के लिए, मुख्य थ्रेड से बाहर कार्रवाई करने में ज़्यादा समय लगता है इंटरफ़ेस पर कॉपी करने की सुविधा मिलती है. क्योंकि ऐसा हो सकता है कि Fragment या Activity में मान को बनाए रखते हुए नष्ट किया जाने वाला Datastore, डेटा को क्रम से लगाएं. ऐसा करने के लिए उन वैल्यू को खोने से नहीं बचा जा सकता जिनमें उपयोगकर्ता ने बदलाव किया है.

डेटास्टोर चालू करें

डेटास्टोर लागू करने के बाद, नए डेटास्टोर को onCreatePreferences() ताकि Preference ऑब्जेक्ट, डेटास्टोर के बजाय डिफ़ॉल्ट SharedPreferences का उपयोग करें. आप हर Preference या पूरे क्रम के लिए डेटास्टोर.

अगर आपको किसी खास Preference के लिए कस्टम डेटा स्टोर चालू करना है, तो कॉल करें setPreferenceDataStore() Preference पर, जैसा कि इस उदाहरण में दिखाया गया है:

Kotlin

 val preference: Preference? = findPreference("key") preference?.preferenceDataStore = dataStore 

Java

 Preference preference = findPreference("key"); if (preference != null) {     preference.setPreferenceDataStore(dataStore); } 

अगर आपको पूरे क्रम के लिए कस्टम डेटा स्टोर चालू करना है, तो PreferenceManager को setPreferenceDataStore():

Kotlin

 val preferenceManager = preferenceManager preferenceManager.preferenceDataStore = dataStore 

Java

 PreferenceManager preferenceManager = getPreferenceManager(); preferenceManager.setPreferenceDataStore(dataStore); 

किसी खास Preference के लिए सेट किया गया डेटास्टोर ऐसे किसी भी डेटास्टोर को बदल देता है जो को संगत पदानुक्रम के लिए सेट किया गया है. ज़्यादातर मामलों में, आप ट्रैक किया जा सकता है.