【android】 Android4.1のserviceでdefaultPreferenceがおかしい
公開日:
:
android
【現象】
ActivityでdefaultPreferencesで保存したデータがservice内で取得したdefaultPreferencesから取り出せなかった。
下記のような流れがあったときに1と2で同じログが吐かれてdefaultPreferencesで書いたデータが反映されてない様子。
2.3では期待通り動作したので、バグか使用変更か、はたまた機種依存か、最近この手の動作違いに苦労させられます。
【コード】
MainActivity.java
SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(context); Editor editor = sp.edit(); editor.putBoolean("hoge", "poyo1"); editor.commit(); startService(intent); //ここでService.javaからログにpoyo1と出力してほしい --1 SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(context); Editor editor = sp.edit(); editor.putBoolean("hoge", "poyo2"); editor.commit(); startService(intent); //ここでService.javaからログにpoyo2と出力してほしい --2
MyService.java
@Override public int onStartCommand(Intent intent, int flags, int startId){ SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(con); String val = sp.getString("hoge", "def"); Log.v(TAG, val); return super.onStartCommand(intent, flags, startId); }
【結局】
intentにputExExtraして渡すことにしました。
関連記事
-
-
【android】Activityとプロセスのライフサイクル
またもやライフサイクル周りでハマったのですが、Androidのライフサイクルは複雑で困ります。 G
-
-
【android】IMEの表示/非表示
//IMEを閉じる InputMethodManager inputMethodManager
-
-
【android】ハードウェアキー入力を検出する
Activityを継承したクラスで下記を記述します。 public boolean
-
-
【android】アニメーション
Viewにアニメーションを付加する方法です。 目次 アニメーションの実行 de
-
-
[android] ActivityとFragmentのライフサイクルいろいろ
Fragmentを使い始めてライフサイクル関係でハマることがあったので備忘録。 FragmentA
-
-
【android】非同期処理
Androidで非同期処理、マルチスレッドを処理するスニペット。 AndroidのスレッドはUIス
-
-
【android】webviewでアプリ内にwebページを読み込む
webviewを使ってandroidアプリ内にwebページを読み込む定型文です。 //vie
-
-
ダイアログを表示する
カスタムアラートダイアログ private void showCustomAlert(A
-
-
【android】任意のスレッドで処理を行う
非UIスレッドでUIを操作したい場合に、任意の処理をUIスレッド上で実行する。 目次