SharedPreferences в классе обслуживания не работает (нулевой указатель)

Я уже много исследовал здесь, чтобы решить мою проблему. Я хочу, чтобы при создании действия оно выполняло метод из класса обслуживания. Это мой код: MenuActivity.class:

public class MenuActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
    //...
    BgService tracker = new BgService();
    tracker.changeIntent();
    SharedPreferences prefs = getSharedPreferences(PREFS_NAME, Activity.MODE_PRIVATE);
    int intentstarts = prefs.getInt("intentstarts",0);
    Toast.makeText(MenuActivity.this,String.valueOf(intentstarts), Toast.LENGTH_LONG).show();
    //...
}}

BgService.класс

public class BgService extends Service {
public static String PREFS_NAME = "MyPrefsFile";
public void changeIntent(){
    Context context = getApplicationContext();
    SharedPreferences prefs = context.getSharedPreferences(PREFS_NAME, Context.MODE_PRIVATE);
    //SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
    int intentstarts = prefs.getInt("intentstarts",0);
    intentstarts++;
    SharedPreferences.Editor edit = prefs.edit();
    edit.putInt("intentstarts", intentstarts).commit();
}}

logcat (мне пришлось подвергнуть цензуре имя пакета):

02-27 19:23:49.265: E/AndroidRuntime(1092): FATAL EXCEPTION: main
02-27 19:23:49.265: E/AndroidRuntime(1092): java.lang.RuntimeException: Unable to      start activity ComponentInfo{com.xxx.xxxxxxx/com.xxx.xxxxxxx.MenuActivity}: java.lang.NullPointerException
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.os.Handler.dispatchMessage(Handler.java:99)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.os.Looper.loop(Looper.java:123)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.app.ActivityThread.main(ActivityThread.java:3683)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at java.lang.reflect.Method.invokeNative(Native Method)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at java.lang.reflect.Method.invoke(Method.java:507)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at dalvik.system.NativeStart.main(Native Method)
02-27 19:23:49.265: E/AndroidRuntime(1092): Caused by: java.lang.NullPointerException
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.content.ContextWrapper.getApplicationContext(ContextWrapper.java:100)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at com.xxx.xxxxxxx.BgService.changeIntent(BgService.java:36)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at com.xxx.xxxxxxx.MenuActivity.onCreate(MenuActivity.java:33)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
02-27 19:23:49.265: E/AndroidRuntime(1092):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
02-27 19:23:49.265: E/AndroidRuntime(1092):     ... 11 more

Было бы неплохо, если бы вы могли найти решение для меня.

редактировать: после замены «контекста» на «это»: используя это вместо контекста:

SharedPreferences prefs = this.getSharedPreferences(PREFS_NAME, 0);

02-27 21:01:57.560: E/AndroidRuntime(1316): FATAL EXCEPTION: main
02-27 21:01:57.560: E/AndroidRuntime(1316): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.xxx.xxxxxxx/com.xxx.xxxxxxx.MenuActivity}: java.lang.NullPointerException
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.os.Handler.dispatchMessage(Handler.java:99)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.os.Looper.loop(Looper.java:123)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.app.ActivityThread.main(ActivityThread.java:3683)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at java.lang.reflect.Method.invokeNative(Native Method)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at java.lang.reflect.Method.invoke(Method.java:507)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at dalvik.system.NativeStart.main(Native Method)
02-27 21:01:57.560: E/AndroidRuntime(1316): Caused by: java.lang.NullPointerException
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.content.ContextWrapper.getSharedPreferences(ContextWrapper.java:146)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at com.xxx.xxxxxxx.BgService.changeIntent(BgService.java:36)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at com.xxx.xxxxxxx.MenuActivity.onCreate(MenuActivity.java:33)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
02-27 21:01:57.560: E/AndroidRuntime(1316):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
02-27 21:01:57.560: E/AndroidRuntime(1316):     ... 11 more

person user3362035    schedule 27.02.2014    source источник
comment
почему вы используете getApplicationContext() в своей службе? Служба может работать, а ваше приложение — нет, поэтому используйте собственный контекст Службы, чтобы получить свои SharedPreferences.   -  person panini    schedule 27.02.2014
comment
если я удалю контекст, это даст мне 02-27 19:46:06.940: E/AndroidRuntime(1202): at android.content.ContextWrapper.getSharedPreferences(ContextWrapper.java:146)   -  person user3362035    schedule 27.02.2014
comment
Activity вызывает службу, 2 разных класса.   -  person user3362035    schedule 27.02.2014


Ответы (3)


Вам нужно связать активность со службой для вызова методов службы. Образец кода -

public class LocalService extends Service {
// Binder given to clients
private final IBinder mBinder = new LocalBinder();
// Random number generator
private final Random mGenerator = new Random();

/**
 * Class used for the client Binder.  Because we know this service always
 * runs in the same process as its clients, we don't need to deal with IPC.
 */
public class LocalBinder extends Binder {
    LocalService getService() {
        // Return this instance of LocalService so clients can call public methods
        return LocalService.this;
    }
}

@Override
public IBinder onBind(Intent intent) {
    return mBinder;
}

/** method for clients */
public int getRandomNumber() {
  return mGenerator.nextInt(100);
 }
}

public class BindingActivity extends Activity {
LocalService mService;
boolean mBound = false;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
}

@Override
protected void onStart() {
    super.onStart();
    // Bind to LocalService
    Intent intent = new Intent(this, LocalService.class);
    bindService(intent, mConnection, Context.BIND_AUTO_CREATE);
}

@Override
protected void onStop() {
    super.onStop();
    // Unbind from the service
    if (mBound) {
        unbindService(mConnection);
        mBound = false;
    }
}

/** Called when a button is clicked (the button in the layout file attaches to
  * this method with the android:onClick attribute) */
public void onButtonClick(View v) {
    if (mBound) {
        // Call a method from the LocalService.
        // However, if this call were something that might hang, then this request should
        // occur in a separate thread to avoid slowing down the activity performance.
        int num = mService.getRandomNumber();
        Toast.makeText(this, "number: " + num, Toast.LENGTH_SHORT).show();
    }
}

/** Defines callbacks for service binding, passed to bindService() */
private ServiceConnection mConnection = new ServiceConnection() {

    @Override
    public void onServiceConnected(ComponentName className,
            IBinder service) {
        // We've bound to LocalService, cast the IBinder and get LocalService instance
        LocalBinder binder = (LocalBinder) service;
        mService = binder.getService();
        mBound = true;
    }

    @Override
    public void onServiceDisconnected(ComponentName arg0) {
        mBound = false;
    }
};
}

Подробности можно найти здесь — http://developer.android.com/guide/components/bound-services.html#Binder Думаю, вам будет достаточно расширения класса связывателя. Там же описаны и другие методы.

person Ratul Ghosh    schedule 28.02.2014
comment
Спасибо, это решило мою проблему. Печально, что я не могу использовать mService.method(); в onCreate, но nvm, спасибо. - person user3362035; 01.03.2014

Это происходит потому, что вы используете getApplicationContext() в своем Service. Service сам по себе является Context, поэтому используйте его вместо getApplicationContext().

person nKn    schedule 27.02.2014
comment
вы хотите использовать это вместо getApplicationContext()? В этом случае он выдает: 02-27 19:53:46.013: E/AndroidRuntime(1238): at android.content.ContextWrapper.getSharedPreferences(ContextWrapper.java:146) - person user3362035; 27.02.2014
comment
Это должно быть что-то другое, использование this в вашем Service должно быть в порядке. - person nKn; 28.02.2014
comment
Я отредактировал свой первый пост с новым журналом. Используя это, но все равно получайте ошибку. - person user3362035; 28.02.2014
comment
Неправильно – getApplicationContext совершенно нормально – удалите это - person Mr_and_Mrs_D; 28.02.2014

BgService tracker = new BgService(); - о боже, вы не должны создавать службы и действия самостоятельно. Эти классы создаются андроидом, и таким образом они получают контекст. Просто контекст в вашем случае нулевой - для аналогичного случая с активностью см. pointer-excep/16391156#16391156">Почему getApplicationContext() в конструкторе Activity выдает исключение нулевого указателя?

Вы должны немного прочитать об Android и переосмыслить свой дизайн

person Mr_and_Mrs_D    schedule 28.02.2014