2

プログラムを実行するとクラス キャスト例外エラーが発生し続けますが、その理由がよくわかりません。

エラー

02-18 14:31:27.585: ERROR/AndroidRuntime(325): FATAL EXCEPTION: main
02-18 14:31:27.585: ERROR/AndroidRuntime(325): java.lang.RuntimeException: Unable to start receiver com.app.notifyme.SmsReciever: java.lang.ClassCastException: java.lang.String
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at android.app.ActivityThread.handleReceiver(ActivityThread.java:2821)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at android.app.ActivityThread.access$3200(ActivityThread.java:125)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2083)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at android.os.Handler.dispatchMessage(Handler.java:99)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at android.os.Looper.loop(Looper.java:123)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at android.app.ActivityThread.main(ActivityThread.java:4627)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at java.lang.reflect.Method.invokeNative(Native Method)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at java.lang.reflect.Method.invoke(Method.java:521)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at dalvik.system.NativeStart.main(Native Method)
02-18 14:31:27.585: ERROR/AndroidRuntime(325): Caused by: java.lang.ClassCastException: java.lang.String
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at android.app.ContextImpl$SharedPreferencesImpl.getInt(ContextImpl.java:2706)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at com.app.notifyme.SmsReciever.onReceive(SmsReciever.java:45)
02-18 14:31:27.585: ERROR/AndroidRuntime(325):     at android.app.ActivityThread.handleReceiver(ActivityThread.java:2810)

今、私がその権利を読んだ場合、エラーは SmsReciever の 45 行目にあり、これが問題の領域になると言っています。

SharedPreferences pref = PreferenceManager.getDefaultSharedPreferences(context);
unread = pref.getInt(SmsPrefs.COUNT, 0);

私はすべてをそのように定義しています

private int unread = 0;
//in preference class
public static final String COUNT = "";

この変数を使用してカウントを維持しようとしています。私は本当に問題を見ていないので、誰かが私をここに案内してくれません。

更新* **

コードはどうですか

public class SmsReciever extends BroadcastReceiver {

static final String ACTION = "android.provider.Telephony.SMS_RECEIVED";

NotificationManager notifyManag;

String mLast = new String();
private int unread = 0;

@Override
public void onReceive(Context arg0, Intent arg1) {

    boolean smsOn = false;
    String smsColor = new String ("Green");
    Uri smsSound;
    String smsVibrate = new String ("Normal");


    SharedPreferences pref = PreferenceManager.getDefaultSharedPreferences(arg0);

     smsOn = pref.getBoolean("PREF_SMS_ON", false);
     smsColor = pref.getString("SMS_PREF_COLOR", "Green");
     smsSound = Uri.parse(pref.getString("SMS_PREF_SOUND", "Silent"));
     smsVibrate = pref.getString("SMS_PREF_SOUND", "Normal");
     unread = pref.getInt(SmsPrefs.COUNT, 0);
     mLast = pref.getString(SmsPrefs.LAST, "");

       NotificationManager mNotificationManager = (NotificationManager) arg0.getSystemService(Context.NOTIFICATION_SERVICE);
        if (arg1.getAction().equals(ACTION) && smsOn == true){
            String from = new String();
            String body = new String();

            Bundle bundle = arg1.getExtras();
            if (bundle != null) {
                Object[] pdus = (Object[]) bundle.get("pdus");
                for (Object pdu : pdus){
                SmsMessage messages = SmsMessage.createFromPdu((byte[]) pdu);
                from = messages.getDisplayOriginatingAddress();
                body= messages.getDisplayMessageBody();
                }// end for
            }//end if

            int icon = 0;
            CharSequence tickerText = null;
            long when = 0;
            SharedPreferences.Editor editor = pref.edit();

            icon = icon(icon);
            tickerText = from + ": " + body;
            when = System.currentTimeMillis();
            CharSequence contentText = "";
            CharSequence contentTitle = "";

            /*
             if no notifications do normal
             else if notified >= 1 and last message is from same person display name and how many messages
             else if(notified >=1 and last message is from different display new message and how many
             */
            if(unread == 0){
                contentTitle = from;
                contentText = body.toString();
                unread = 1;
                editor.putInt(SmsPrefs.COUNT, unread);
                editor.commit();
            }else if(unread >= 1 && mLast.equals(from)){
                contentTitle = from;
                contentText = unread + " unread messages";
                unread++;
                editor.putInt(SmsPrefs.COUNT, unread);
                editor.commit();
            }else if(unread >= 1 && !mLast.equals(from)){
                contentTitle = "New Messages";
                contentText = unread + " unread messages";
                unread++;
                editor.putInt(SmsPrefs.COUNT, unread);
                editor.commit();
            }

            mLast = from;
            editor.putString(SmsPrefs.LAST, mLast);
            editor.commit();

設定アクティビティでは、前に示したように定義されたカウントがあり、文字列に何かを入れてみましたが、それでも同じ結果です

4

5 に答える 5

4

COUNTの設定に何を保存していますか?誤ってint値を文字列として格納した可能性があります。

私が思うように、あなたのコードにはこのようなものがあります:

int a = 1;
prefs.putInt(COUNT, a);
String LAST = "";
prefs.putString(LAST, "NAME");
prefs.commit();
...

その後、prefs.getInt(COUNT)を実行しますが、LASTとCOUNTが同じキーに解決されるため、実行中に失敗するはずです。

于 2011-02-19T06:29:54.527 に答える
3

SharedPreferences.getInt()ドキュメント 言います:

int ではないこの名前のプリファレンスがある場合、ClassCastException をスローします。

したがって、それが何であるかを判断するには:

getAll次のようにafterを呼び出しますSharedPreferences pref = Preferenc...

SharedPreferences pref = Preferenc...
Map<String,?> allPrefs = pref.getAll();
Log.i("xx",allPrefs); // Dummy , put break point here

デバッガーでアプリに接続し、マークされた行にブレークポイントを置き、デバッガーがキーのallPrefsマップに表示する内容を確認しCOUNTます。

于 2011-02-20T21:12:13.237 に答える
0

値を保存する場所はどこでも、その場合は int 値の文字列を変換するか、上記の回答を次のように使用する必要があります。

整数値の後に .tostring() が続きます。文字列に任意の整数値を割り当てることができます。

例えば:

Textview mtxtname= new Textview(this);
mtxtname.setText(19);

クラスキャスト例外が発生するため、文字列を保存または変換してからsetText値を変換する必要があります。

String s= 19+"";
mtextname.settext(s.tostring()); 
于 2014-03-21T07:31:52.273 に答える
0

宣言フィールドprivateから削除することで、この問題を修正しました。SharedPreferences

于 2013-04-10T00:47:17.477 に答える
0

一部の古いアンドロイド (<= 4) では、getBoolean、getInt、getString... 変数を初期化して保存していない場合は ClassCastException をスローします。

つまり、解決策は次のとおりです。

type foo;
try{
   foo = sharedPreferences.getANYTING("name", defaultValue);
}
catch( ClassCastException e ){
    foo = defaultValue;
}
于 2017-06-24T13:26:13.807 に答える