I have a class with all static members which I need to use for saving my datas in a wide scope, using them in all activities. Now, all is working fine after the first run of the application, but this first time run always crushes. I have a SplashScreen which should initialize the class with default values but it is always null. Here is the call from splash:
LocalSettings.LoadSettings();
and here is the Class. PS: the SETTING variable is a table i used for saving datas on the local DB. It has same variables of LocalSettings class.
public class LocalSettings {
public LocalSettings(){}
private static Enums.TIPO_PERIODO periodoVisualizzato;
private static Calendar dataSpecificaPeriodoVisualizzazione;
private static Calendar dataInizioPeriodoVisualizzazione;
private static Calendar dataFinePeriodoVisualizzazione;
private static CATEGORIA categoriaSpecificaPeriodoVisualizzazione;
public static void LoadSettings(){
List<SETTINGS> settings = SETTINGS.listAll(SETTINGS.class);
if(settings == null || settings.isEmpty()){
SETTINGS setting = new SETTINGS();
setting.setPERIODOVISUALIZZATO(Enums.TIPO_PERIODO.SEMPRE);
setting.setGIORNOINIZIOPERIODOVISUALIZZAZIONE(Calendar.getInstance());
setting.setGIORNOFINEPERIODOVISUALIZZAZIONE(Calendar.getInstance());
setting.setDATASPECIFICAPERIODOVISUALIZZAZIONE(Calendar.getInstance());
setting.setCATEGORIASPECIFICAPERIODOVISUALIZZAZIONE(new CATEGORIA("", 0));
setting.save();
}else{
SETTINGS setting = settings.get(0);
setPeriodoVisualizzato(setting.getPERIODOVISUALIZZATO());
setDataInizioPeriodoVisualizzazione(setting.getGIORNOINIZIOPERIODOVISUALIZZAZIONE());
setDataFinePeriodoVisualizzazione(setting.getGIORNOFINEPERIODOVISUALIZZAZIONE());
setDataSpecificaPeriodoVisualizzazione(setting.getDATASPECIFICAPERIODOVISUALIZZAZIONE());
setCategoriaSpecificaPeriodoVisualizzazione(setting.getCATEGORIASPECIFICAPERIODOVISUALIZZAZIONE());
}
}
public static void SaveSettings(){
List<SETTINGS> settings = SETTINGS.listAll(SETTINGS.class);
SETTINGS setting;
if(settings == null || settings.isEmpty()){
setting = new SETTINGS();
}else{
setting = settings.get(0);
}
setting.setPERIODOVISUALIZZATO(getPeriodoVisualizzato());
setting.setGIORNOFINEPERIODOVISUALIZZAZIONE(getDataFinePeriodoVisualizzazione());
setting.setGIORNOINIZIOPERIODOVISUALIZZAZIONE(getDataInizioPeriodoVisualizzazione());
setting.setDATASPECIFICAPERIODOVISUALIZZAZIONE(getDataSpecificaPeriodoVisualizzazione());
setting.setCATEGORIASPECIFICAPERIODOVISUALIZZAZIONE(getCategoriaSpecificaPeriodoVisualizzazione());
setting.save();
}
public static void ResetSettings(){
setPeriodoVisualizzato(Enums.TIPO_PERIODO.SEMPRE);
setDataFinePeriodoVisualizzazione(Calendar.getInstance());
setDataInizioPeriodoVisualizzazione(Calendar.getInstance());
setDataSpecificaPeriodoVisualizzazione(Calendar.getInstance());
setCategoriaSpecificaPeriodoVisualizzazione(new CATEGORIA("", 0));
}
//getters and setters below
I'm stuck here since some hours and even on the net I didn't find anything that solved my problem. Any help will be appreciated
EDIT: this is where i get the nullPointerException, in "HomePageActivity":
TIPO_PERIODO period = LocalSettings.getPeriodoVisualizzato();
String periodString = period.name();
this is TIPO_PERIODO enum:
public enum TIPO_PERIODO{
GIORNO, MESE, ANNO, SEMPRE, PERIODO_PERSONALIZZATO, CATEGORIA;
public static List<String> ListAll(){
ArrayList<String> tipi = new ArrayList<>();
for(TIPO_PERIODO tp : TIPO_PERIODO.values()){
tipi.add(tp.name());
}
return tipi;
}
}
and this is the full stack trace:
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: FATAL EXCEPTION: main
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: Process: com.example.piermisley.Activities, PID: 15902
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.piermisley.Activities/com.example.piermisley.Activities.HomePageActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String com.example.piermisley.Classes.Enums$TIPO_PERIODO.name()' on a null object reference
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2356)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2418)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread.access$900(ActivityThread.java:154)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1321)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.os.Looper.loop(Looper.java:135)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:5289)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at java.lang.reflect.Method.invoke(Method.java:372)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:904)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:699)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String com.example.piermisley.Classes.Enums$TIPO_PERIODO.name()' on a null object reference
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at com.example.piermisley.Activities.HomePageActivity.LoadList(HomePageActivity.java:100)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at com.example.piermisley.Activities.HomePageActivity.LoadPageDatas(HomePageActivity.java:438)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at com.example.piermisley.Activities.HomePageActivity.onCreate(HomePageActivity.java:80)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.Activity.performCreate(Activity.java:5990)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2309)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2418)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread.access$900(ActivityThread.java:154)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1321)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.os.Looper.loop(Looper.java:135)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:5289)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at java.lang.reflect.Method.invoke(Method.java:372)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:904)
10-14 12:50:55.196 15902-15902/? E/AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:699)
EDIT: ps: my problem is not the exception, my problem is the null static class on first app's run. :)