2011-12-28 12 views
1

これは、の一部の ICSデバイスでのみ発生します。intent.getExtras()が呼び出されるとICSがクラッシュする

私のアプリがやっていることは、基本的にブロードキャストを待ってから、インテントでサービスを開始することです。

意図がしかし、このスタックトレースにつながるいくつかのICSデバイス上

@Override 
public void onStart(Intent intent, int startId) { 
    sets = new SettingsClass(this); 
    Bundle extras = intent.getExtras(); 

で読み出される添付のバンドルを、しています

java.lang.RuntimeException: Unable to start service [email protected] with null: java.lang.NullPointerException 
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2375) 
at android.app.ActivityThread.access$1900(ActivityThread.java:122) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1209) 
at android.os.Handler.dispatchMessage(Handler.java:99) 
at android.os.Looper.loop(Looper.java:137) 
at android.app.ActivityThread.main(ActivityThread.java:4340) 
at java.lang.reflect.Method.invokeNative(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:511) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
at dalvik.system.NativeStart.main(Native Method) 
Caused by: java.lang.NullPointerException 
at de.bulling.smstalk.Services.TTS.onStart(TTS.java:48) 
at android.app.Service.onStartCommand(Service.java:438) 
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2358) 
... 10 more 
java.lang.NullPointerException 
at de.bulling.smstalk.Services.TTS.onStart(TTS.java:48) 
at android.app.Service.onStartCommand(Service.java:438) 
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2358) 
at android.app.ActivityThread.access$1900(ActivityThread.java:122) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1209) 
at android.os.Handler.dispatchMessage(Handler.java:99) 
at android.os.Looper.loop(Looper.java:137) 
at android.app.ActivityThread.main(ActivityThread.java:4340) 
at java.lang.reflect.Method.invokeNative(Native Method) 
at java.lang.reflect.Method.invoke(Method.java:511) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
at dalvik.system.NativeStart.main(Native Method) 

言及ライン48 ですエクストラが読まれる行。このように私が以前使っていた別のサービスでも同じ例外が発行されました。

ここで質問:この問題を解決するにはどうすればよいですか?サービスを開始してデータを渡す別の方法がありますか?getExtras()を間違った場所に電話するのですか?

ありがとうございます!そのONSTARTがdeprecatedかもしれないよう

+0

はあなたが意図変数がNULLでないデバッグにチェックインした方法を試してみましたが、見えますか?私はなぜそれがどうなるのか分からないが、おそらく問題を引き起こしている。 – MikeIsrael

+0

まあ、それはここで問題があるようです(そうでなければ、その厄介な例外はありません)。しかし、サービス自体は開始されません(またはICS上で再起動されるのでしょうか?)、それは受信側からのみ開始されます。 しかし、私はこの問題をANICSエミュレータで再現できません。 – Force

答えて

2

それはあなたが

@Override 

public int onStartCommand(Intent intent, int flags, int startId) 
+0

ダン!私はonStartが廃止されたことを知らなかった!どうもありがとう! – Force

+1

私の喜び、また活動のためのonStart()はまだ非常に使用されているので、ちょっと混乱することがあります:) – MikeIsrael

関連する問題