0

私のアプリケーションでは、BluetoothChat の例から派生したクラス DeviceListActivity のわずかに変更されたバージョンを使用しています。コードはテストしたすべてのデバイスでうまく機能しましたが、アプリケーションを公開すると、次のようなレポートを受け取り始めました。

java.lang.StringIndexOutOfBoundsException: String index out of range: -1
at java.lang.String.substring(String.java:1555)
at sword.games.highnoonf.activities.DeviceListActivity$1.onItemClick(DeviceListActivity.java:18    0)
at android.widget.AdapterView.performItemClick(AdapterView.java:284)
at android.widget.ListView.performItemClick(ListView.java:3388)
at android.widget.AbsListView$PerformClick.run(AbsListView.java:1738)
at android.os.Handler.handleCallback(Handler.java:587)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:143)
at android.app.ActivityThread.main(ActivityThread.java:5097)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)

例外を引き起こす関数は次のとおりです。

private OnItemClickListener mDeviceClickListener = new OnItemClickListener() {
    public void onItemClick(AdapterView<?> av, View v, int arg2, long arg3)       {         
        // Cancel discovery because it's costly and we're about to connect
        mBtAdapter.cancelDiscovery();

        // Get the device MAC address, which is the last 17 chars in the View
        String info = ((TextView) v).getText().toString();
        String address = info.substring(info.length() - 17);
        String devName = info.substring(0, info.length() - 17);

        // Create the result Intent and include the MAC address
        Intent intent = new Intent();
        intent.putExtra(EXTRA_DEVICE_ADDRESS, address);
        intent.putExtra("DEVICE_NAME", devName);

        // Set result and finish this Activity
        setResult(Activity.RESULT_OK, intent);
        finish();
    }
};

コードの残りの部分は、DeviceListActivity の例とほぼ同じです...誰かがこれを修正するか、なぜこれが起こるのか説明してくれることを願っています...ありがとう...

編集: コードは、名前が存在し、MAC アドレスの長さがそれらの行で正しいことを既に確認しています (何か問題が発生した場合、電話は追加されず、ユーザーはそれをクリックできません):

String name = device.getName();
String address = device.getAddress();

if(name == null) name = "Unknown";
else if (name.length() == 0) name = "Unknown";

if (address.length() == 17){
    mNewDevicesArrayAdapter.add(name + "\n" + address);
}
4

1 に答える 1

0

サイズが17info.length()未満のようです。サブストリングメソッドがパラメータとして負の値を取得しないことを確認してください。例外を回避するために、コードの重要な部分をtry/catchブロックに配置します。

于 2012-04-11T19:58:46.503 に答える