【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とFragmentのライフサイクルいろいろ
Fragmentを使い始めてライフサイクル関係でハマることがあったので備忘録。 FragmentA
-
-
【android】IMEの表示/非表示
//IMEを閉じる InputMethodManager inputMethodManager
-
-
【andoid】ViewPagerを使う
1. layout.xmlにViewPagerを配置 2. PagerAdapter.jav
-
-
【android】 APIバージョンによる動作の違い
「最近使用したアプリケーション」からの起動 2.x系 -> onNewIntentが呼ばれる 4
-
-
【android】 年月だけのDatePicker
final DatePicker datePicker = new DatePicker(sel
-
-
【android】 webviewでassetsのリソースを使用する
webviewでassets内のリソースにアクセスするには file:///android_a
-
-
【android】DrawableとBitmap、リソースの相互変換
Resource → Bitmap Bitmap bm = BitmapFactory.dec
-
-
【android】言語・地域設定の取得
androidでは利用する言語と国名がjava.util.Localeのオブジェクトとして設定されて
-
-
【android】ネットワークの接続状況を確認する
コードから接続状況を確認。 ConnectivityManager co
-
-
アプリ間連携 Intentfiler
ブラウザの共有からURLを受け取る。 Manifest.xmlのURL受け取り先のactivity