2012-08-10 190 views
1

這是我SharedPreference類:空指針異常的Android

public class MySharedPrefs { 
private static final String APP_SHARED_PREFS = "com.astroved.Horawatch"; 
private SharedPreferences appSharedPrefs; 
private Editor prefsEditor; 

public MySharedPrefs(Context context) 
{ 
    this.appSharedPrefs = context.getSharedPreferences(APP_SHARED_PREFS, Activity.MODE_PRIVATE); 
    this.prefsEditor = appSharedPrefs.edit(); 
} 

public String getPrefsValue(String value) { 
    return appSharedPrefs.getString(value, ""); 
} 

public void savePrefsValue(String key , String Value) { 
    prefsEditor.putString(key, Value); 
    prefsEditor.commit(); 
} 

public Boolean checkKey(String Key) 
{ 
    if(appSharedPrefs.contains(Key)) 
     return true;  
    else 
     return false; 
} 

}

MyFunctionClass:

public class Functions_class extends Activity{ 


AstroVedTime tz,lat,lon; 
TimeZone tz1; 
protected MySharedPrefs appPrefs; 

public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState);{ 
     appPrefs = new MySharedPrefs(Functions_class.this); 
    } 
    } 

public void user_informations(int myear,int mMonth, int mDay){ 

    int year = myear,month = mMonth+1,day = mDay; 
    Moment mn = new Moment(year,month,day,user_device_time()); 
    //appPrefs = new MySharedPrefs(Functions_class.this); 

    if(appPrefs.checkKey("City_name1")){ 
     TimeZone.setDefault(TimeZone.getTimeZone(appPrefs.getPrefsValue("selected_time_zone"))); 
     Log.v("LOG_TAG"+"here the error is : ", appPrefs.getPrefsValue("selected_lat")+""); 
     Log.v("LOG_TAG", appPrefs.getPrefsValue("selected_longi")+""); 
     tz1 = TimeZone.getDefault(); 
     lat = new AstroVedTime(Double.parseDouble(appPrefs.getPrefsValue("selected_lat")));// Latitude 
     lon = new AstroVedTime(Double.parseDouble(appPrefs.getPrefsValue("selected_longi")));// Longitude 
    } 

這是我logcat

08-10 14:07:14.947: E/AndroidRuntime(475): FATAL EXCEPTION: Thread-13 
08-10 14:07:14.947: E/AndroidRuntime(475): java.lang.NullPointerException 
08-10 14:07:14.947: E/AndroidRuntime(475): at com.astroved.horawatch.Functions_class.user_informations(Functions_class.java:46) 
08-10 14:07:14.947: E/AndroidRuntime(475): at com.astroved.horawatch.HoraWatchActivity$13$1.run(HoraWatchActivity.java:1106) 
08-10 14:07:16.628: E/WindowManager(475): Activity com.astroved.horawatch.HoraWatchActivity has leaked window [email protected] that was originally added here 
08-10 14:07:16.628: E/WindowManager(475): android.view.WindowLeaked: Activity com.astroved.horawatch.HoraWatchActivity has leaked window [email protected] that was originally added here 
08-10 14:07:16.628: E/WindowManager(475): at android.view.ViewRoot.<init>(ViewRoot.java:258) 
08-10 14:07:16.628: E/WindowManager(475): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148) 
08-10 14:07:16.628: E/WindowManager(475): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91) 
08-10 14:07:16.628: E/WindowManager(475): at android.view.Window$LocalWindowManager.addView(Window.java:424) 
08-10 14:07:16.628: E/WindowManager(475): at android.app.Dialog.show(Dialog.java:241) 
08-10 14:07:16.628: E/WindowManager(475): at com.astroved.horawatch.HoraWatchActivity$13.onClick(HoraWatchActivity.java:1103) 
08-10 14:07:16.628: E/WindowManager(475): at android.view.View.performClick(View.java:2485) 
08-10 14:07:16.628: E/WindowManager(475): at android.view.View$PerformClick.run(View.java:9080) 
08-10 14:07:16.628: E/WindowManager(475): at android.os.Handler.handleCallback(Handler.java:587) 
08-10 14:07:16.628: E/WindowManager(475): at android.os.Handler.dispatchMessage(Handler.java:92) 
08-10 14:07:16.628: E/WindowManager(475): at android.os.Looper.loop(Looper.java:123) 
08-10 14:07:16.628: E/WindowManager(475): at android.app.ActivityThread.main(ActivityThread.java:3683) 
08-10 14:07:16.628: E/WindowManager(475): at java.lang.reflect.Method.invokeNative(Native Method) 
08-10 14:07:16.628: E/WindowManager(475): at java.lang.reflect.Method.invoke(Method.java:507) 
08-10 14:07:16.628: E/WindowManager(475): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
08-10 14:07:16.628: E/WindowManager(475): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
08-10 14:07:16.628: E/WindowManager(475): at dalvik.system.NativeStart.main(Native Method) 

我通用電器解決上述錯誤。我在調用SharedPreference值時出錯。我無法弄清楚。以前我得到這個錯誤

at android.content.contextwrapper.getsharedpreferences contextwrapper.java 146 

我通過調用OnCreateSharedPreferences清除上述錯誤。如何清除上面顯示的Logcat錯誤。我錯了嗎?

我打電話下面

HoraWatchActivity所示的另一個我的activity.Its的onclick過程中MyFunctionClass方法:

public Functions_class func_cls = new Functions_class(); 
private OnClickListener show_panchang_page = new OnClickListener(){ 

    public void onClick(View v) { 

     pbarDialog = new ProgressDialog(HoraWatchActivity.this); 
     pbarDialog.setProgressStyle(ProgressDialog.STYLE_SPINNER); 
     pbarDialog.setMessage("Loading Panchang..."); 
     pbarDialog.show(); 
       Thread t = new Thread(){ 
        public void run(){ 
         func_cls.user_informations(mYear, mMonth, mDay); 
         Message myMessage=new Message(); 
         Bundle resBundle = new Bundle(); 
         resBundle.putString("status", "SUCCESS"); 
         myMessage.obj=resBundle; 
         handler.sendMessage(myMessage); 
        } 
       }; 
       t.start(); 
    } 
}; 

更快響應將幫助我Lot.Thanks。

+1

裏面我認爲錯誤是HoraWatchActivity。 java。不是他在這裏發佈的一個。 – 2012-08-10 09:11:37

+0

@AndroSelva:我在HoraWatchActivity中調用了MyFunctionClass中的方法。該錯誤顯示在if(appPrefs.checkKey(「City_name1」))....所以我認爲錯誤正在重試SharedPreference值。我對嗎? – Dray 2012-08-10 09:17:03

+0

你可否請張貼那部分?對事物進行分類會有所幫助。 – 2012-08-10 09:19:47

回答

2

好的發現了問題。問題出在Function classuser_informations這個變量中,appPrefs。它在那一點上是空的。

你在做什麼時,你在的onCreate()發起的appPrefs,但是當你做這樣的事情,你public Functions_class func_cls = new Functions_class();的onCreate不叫,這意味着它直接進入方法並返回null給你。您必須對現有代碼進行一些修改。

試試這個,

1)首先通過你當前活動上下文的方法,

2)取消註釋此行的方法appPrefs = new MySharedPrefs(context);

public void user_informations(int myear,int mMonth, int mDay,Context context){ 

    int year = myear,month = mMonth+1,day = mDay; 
    Moment mn = new Moment(year,month,day,user_device_time()); 
    appPrefs = new MySharedPrefs(context); 

    if(appPrefs.checkKey("City_name1")){ 
     TimeZone.setDefault(TimeZone.getTimeZone(appPrefs.getPrefsValue("selected_time_zone"))); 
     Log.v("LOG_TAG"+"here the error is : ", appPrefs.getPrefsValue("selected_lat")+""); 
     Log.v("LOG_TAG", appPrefs.getPrefsValue("selected_longi")+""); 
     tz1 = TimeZone.getDefault(); 
     lat = new AstroVedTime(Double.parseDouble(appPrefs.getPrefsValue("selected_lat")));// Latitude 
     lon = new AstroVedTime(Double.parseDouble(appPrefs.getPrefsValue("selected_longi")));// Longitude 
    } 
+0

HMmm。再次ThankYou ..所以我沒有通過上下文。我知道了 :) – Dray 2012-08-10 09:48:38

1

您正在手動實例化活動類Functions_class。如果您開始該活動,該框架將處理此問題。即使Functions_class沒有被用作一個活動,那麼你將不得不手動調用Function_class的createcreate。這就是appPrefs正在初始化的地方。 user_informations函數中的appPrefs爲null。初始化它。

+0

我已初始化appPrefs在user_information.During時間只有我得到了 在android.content.contextwrapper.getsharedpreferences contextwrapper.java 146 錯誤。所以我在OnCreate中初始化。我直接從另一個函數調用user_informations函數。這不會初始化Func_class的Oncreate中的appPrefs。如何發起這個? – Dray 2012-08-10 09:38:25

+0

你是否正確。我明白了。 thnks :) – Dray 2012-08-10 09:49:18

1

我認爲你的方法是錯誤的,因爲你正在調用一個Activity的方法(iefunc_cls.user_informations(mYear,mMonth,mDay);),它沒有從可見的Activity(HoraWatchActivity.this)中獲得焦點。函數除了從共享首選項中獲取價值外無所作爲。數據檢索應該在NonActivity類中完成.appPrefs不是初始化的。

+0

Thnks ...我得到它 – Dray 2012-08-10 09:48:59