डबल साझाप्रदर्शन नहीं कर सकते


90

त्रुटि हो रही है, इस तरह के शेयर्स को साझा करने के लिए विधि अपरिभाषित है। इस तरह के शेयर्स के संपादक के लिए ग्रहण किया जाता है। ग्रहण को संपादक के लिए एक त्वरित फिक्स ऐड दिया जाता है, लेकिन जब मैं ऐसा करता हूं कि इसकी अभी भी दी गई त्रुटियां हैं, तो कठबोली को मैंने डबल क्यों रखा।

कोड:

@Override
protected void onPause() {
    // TODO Auto-generated method stub
    super.onPause();

    if (TextUtils.isEmpty(editBl.getText().toString())) {
        numberOfBl = 0;
    } else {
        numberOfBl = Integer.parseInt(editBl.getText().toString();

    }
    if (TextUtils.isEmpty(editSt.getText().toString())) {
        tonOfSt = 0;
    } else {
        tonOfSt = Double.parseDouble(editSt.getText().toString());

    }

    SharedPreferences prefs = getSharedPreferences(
            "SavedTotals", Context.MODE_PRIVATE);

    SharedPreferences.Editor editor = prefs.edit();

    editor.putInt("savedBl", numberOfBl);
    editor.putDouble("savedSt", tonOfSt);


    editor.commit();
}

2
क्या आप कृपया बता सकते हैं कि आपको क्या त्रुटि मिली है?
डम्बलिंगर्स

1
प्रश्न की पहली पंक्ति देखें
रॉबर्ट

मुझे आश्चर्य है कि कैसे आता है कि Android लोग एपीआई में putDouble लागू नहीं किया था?
लूसी

जवाबों:


336

जिन्होंने पुटफ्लोत और उपयोग करने का सुझाव दिया getFloat वे दुर्भाग्य से बहुत गलत हैं। फ्लोट में डबल कास्टिंग करने के परिणामस्वरूप हो सकता है

  1. शुद्धता खो दी
  2. बाढ़
  3. underflow
  4. मृत बिल्ली के बच्चे

वे एक toString और parseString का सुझाव दे रहे हैं गलत नहीं हैं, लेकिन यह एक अक्षम समाधान है।

इससे निपटने का सही तरीका यह है कि डबल को अपने 'रॉ लॉन्ग बिट्स' के बराबर कन्वर्ट किया जाए और उस लंबे स्टोर को स्टोर किया जाए। जब आप मान पढ़ रहे हों, तो वापस डबल में बदलें।

क्योंकि दो डेटा प्रकारों का आकार समान है, आप सटीक नहीं खोते हैं और आप {प्रवाह के तहत {over, flow} का कारण नहीं बनेंगे।

Editor putDouble(final Editor edit, final String key, final double value) {
   return edit.putLong(key, Double.doubleToRawLongBits(value));
}

double getDouble(final SharedPreferences prefs, final String key, final double defaultValue) {
return Double.longBitsToDouble(prefs.getLong(key, Double.doubleToLongBits(defaultValue)));
}

वैकल्पिक रूप से आप गेट्टर को इस प्रकार लिख सकते हैं:

double getDouble(final SharedPreferences prefs, final String key, final double defaultValue) {
if ( !prefs.contains(key))
        return defaultValue;

return Double.longBitsToDouble(prefs.getLong(key, 0));
}

9
इतना सुंदर, स्वच्छ और सुरुचिपूर्ण।
बोगदान अलेक्जेंड्रू

9
एंड्रॉइड इकोसिस्टम के भीतर अन्य एपीआई के साथ (जैसे कि पार्सिबल और बंडलों) के साथ एक putDouble विधि अभी भी अच्छी और सुसंगत होगी। Google का एक विशिष्ट मामला फिर से तेज़ और सुस्त होना।

2
इसे स्ट्रिंग के रूप में सहेजना अक्षम क्यों है?
केकेओ

2
@KKO लंबा डेटा प्रकार 64-बिट दो का पूरक पूर्णांक है। तो यह केवल 4-बाइट्स लेता है। लेकिन अगर आप उस doubleमूल्य को एक स्ट्रिंग के रूप में संग्रहीत करते हैं तो आप अपने भंडारण को बर्बाद करते हैं और इसे एक मलबे बनाते हैं !!
सेमसामोट

1
prefs.getLong (कुंजी, 0d) गलत यह एक डबल नहीं है। डी के बिना होना चाहिए।
अहमद हेगज़ी

27

कोटलिन एक्सटेंशन का रास्ता (अजीब बर्तन वर्गों या जो कुछ भी उपयोग करने की तुलना में बहुत अधिक सुंदर है)

fun SharedPreferences.Editor.putDouble(key: String, double: Double) =
    putLong(key, java.lang.Double.doubleToRawLongBits(double))

fun SharedPreferences.getDouble(key: String, default: Double) =
    java.lang.Double.longBitsToDouble(getLong(key, java.lang.Double.doubleToRawLongBits(default)))

2
महान, मैं इसे यहाँ डालने के बारे में सोच रहा था। धन्यवाद!
वजीबा

16

मैंने जो किया वह एक स्ट्रिंग के रूप में वरीयता को बचाने के लिए किया गया था:

getSharedPreferences("PREFERENCE", MODE_PRIVATE).edit().putString("double", "0.01").commit();

और फिर डबल को पुनः प्राप्त करने के लिए, बस Double.parseDouble का उपयोग करें:

Double.parseDouble(getSharedPreferences("PREFERENCE", MODE_PRIVATE).getString("double", "0.01"));

4
आप भंडारण को बर्बाद कर रहे हैं। यह doubleToRawLongBitsपहले से उल्लिखित विधि की तुलना में बहुत धीमा है । यह गलत तरीका है, इसलिए नहीं कि यह काम नहीं करेगा, बल्कि इसलिए कि यह बहुत अक्षम है।
20

10
@copolii अकादमिक, निश्चित रूप से। व्यावहारिक रूप से, उद्योग में, यह वास्तव में 99% मामलों में फर्क करने के लिए पर्याप्त नहीं है और वास्तव में किसी नए पर लाते समय यह संभवतः अधिक पठनीय और आसान है।
डेनिस एल

@ डेनिसएल #PracticalDev
Aba

9

आप हमेशा SharedPreferences को लागू कर सकते हैं और Android कार्यान्वयन को लपेट सकते हैं।

package com.company.sharedpreferences;

import android.content.Context;
import android.content.SharedPreferences;


import java.util.Map;
import java.util.Set;

public class EnhancedSharedPreferences implements SharedPreferences {

    public static class NameSpaces {
        public static String MY_FUN_NAMESPACE = "MyFunNameSpacePrefs";
    }

    public static EnhancedSharedPreferences getPreferences(String prefsName) {
        return new EnhancedSharedPreferences(SomeSingleton.getInstance().getApplicationContext().getSharedPreferences(prefsName, Context.MODE_PRIVATE));
    }

    private SharedPreferences _sharedPreferences;

    public EnhancedSharedPreferences(SharedPreferences sharedPreferences) {
        _sharedPreferences = sharedPreferences;
    }

    //region Overrides

    @Override
    public Map<String, ?> getAll() {
        return _sharedPreferences.getAll();
    }

    @Override
    public String getString(String key, String defValue) {
        return _sharedPreferences.getString(key, defValue);
    }

    @Override
    public Set<String> getStringSet(String key, Set<String> defValues) {
        return _sharedPreferences.getStringSet(key, defValues);
    }

    @Override
    public int getInt(String key, int defValue) {
        return _sharedPreferences.getInt(key, defValue);
    }

    @Override
    public long getLong(String key, long defValue) {
        return _sharedPreferences.getLong(key, defValue);
    }

    @Override
    public float getFloat(String key, float defValue) {
        return _sharedPreferences.getFloat(key, defValue);
    }

    @Override
    public boolean getBoolean(String key, boolean defValue) {
        return _sharedPreferences.getBoolean(key, defValue);
    }

    @Override
    public boolean contains(String key) {
        return _sharedPreferences.contains(key);
    }

    @Override
    public Editor edit() {
        return new Editor(_sharedPreferences.edit());
    }

    @Override
    public void registerOnSharedPreferenceChangeListener(OnSharedPreferenceChangeListener listener) {
        _sharedPreferences.registerOnSharedPreferenceChangeListener(listener);
    }

    @Override
    public void unregisterOnSharedPreferenceChangeListener(OnSharedPreferenceChangeListener listener) {
        _sharedPreferences.unregisterOnSharedPreferenceChangeListener(listener);
    }

    //endregion

    //region Extension

    public Double getDouble(String key, Double defValue) {
        return Double.longBitsToDouble(_sharedPreferences.getLong(key, Double.doubleToRawLongBits(defValue)));
    }

    //endregion

    public static class Editor implements SharedPreferences.Editor {

        private SharedPreferences.Editor _editor;

        public Editor(SharedPreferences.Editor editor) {
            _editor = editor;
        }

        private Editor ReturnEditor(SharedPreferences.Editor editor) {
            if(editor instanceof Editor)
                return (Editor)editor;
            return new Editor(editor);
        }

        //region Overrides

        @Override
        public Editor putString(String key, String value) {
            return ReturnEditor(_editor.putString(key, value));
        }

        @Override
        public Editor putStringSet(String key, Set<String> values) {
            return ReturnEditor(_editor.putStringSet(key, values));
        }

        @Override
        public Editor putInt(String key, int value) {
            return ReturnEditor(_editor.putInt(key, value));
        }

        @Override
        public Editor putLong(String key, long value) {
            return ReturnEditor(_editor.putLong(key, value));
        }

        @Override
        public Editor putFloat(String key, float value) {
            return ReturnEditor(_editor.putFloat(key, value));
        }

        @Override
        public Editor putBoolean(String key, boolean value) {
            return ReturnEditor(_editor.putBoolean(key, value));
        }

        @Override
        public Editor remove(String key) {
            return ReturnEditor(_editor.remove(key));
        }

        @Override
        public Editor clear() {
            return ReturnEditor(_editor.clear());
        }

        @Override
        public boolean commit() {
            return _editor.commit();
        }

        @Override
        public void apply() {
            _editor.apply();
        }

        //endregion

        //region Extensions

        public Editor putDouble(String key, double value) {
            return new Editor(_editor.putLong(key, Double.doubleToRawLongBits(value)));
        }

        //endregion
    }
}

यह सही जवाब है। काश मैंने टाइप करना शुरू करने से पहले यह देख लिया होता। क्या संपादक के तरीकों में सिर्फ 'यह' वापस करना अधिक कुशल नहीं होगा? यह आपको 'इंस्टोफ़' पद्धति को कॉल करने से बचाता है। या क्या आपने कोशिश की है और इससे समस्याएं पैदा हुई हैं?
कोपलोली

0

इस gist की जाँच करें https://gist.github.com/john1jan/b8cb536ca51a0b2aa1da4e81566869c4

मैंने एक प्राथमिकता उपयोगिता वर्ग बनाया है जो सभी मामलों को संभाल लेगा।

इसका उपयोग करने के लिए आसान है

वरीयता में संग्रहीत

PrefUtils.saveToPrefs(getActivity(), PrefKeys.USER_INCOME, income);

वरीयता से प्राप्त करना

Double income = (Double) PrefUtils.getFromPrefs(getActivity(), PrefKeys.USER_INCOME, new Double(10));
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.