1

私はこのスレッド/投稿のコードに従っていました: Enable bluetooth tethering android programmatically (そしてその後、この投稿: How to check Bluetooth tethering status programmatically in Android )、そして障害に遭遇しました。anirudh reddy のコードを使用しています。行を呼び出すと

setTetheringOn.invoke(instance,true);

NullPointerException が発生します。LogCat スタック トレースは次のとおりです。

12-21 13:11:16.655: W/System.err(12738): java.lang.reflect.InvocationTargetException
12-21 13:11:16.655: W/System.err(12738):    at java.lang.reflect.Method.invoke(Native Method)
12-21 13:11:16.655: W/System.err(12738):    at java.lang.reflect.Method.invoke(Method.java:372)
12-21 13:11:16.655: W/System.err(12738):    at com.myname.android.bluetoothtetheringwidget.BluetoothTetheringActivity.turnBluetoothTetheringOn(BluetoothTetheringActivity.java:50)
12-21 13:11:16.655: W/System.err(12738):    at com.myname.android.bluetoothtetheringwidget.BluetoothTetheringActivity.onCreate(BluetoothTetheringActivity.java:27)
12-21 13:11:16.655: W/System.err(12738):    at android.app.Activity.performCreate(Activity.java:5933)
12-21 13:11:16.655: W/System.err(12738):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
12-21 13:11:16.655: W/System.err(12738):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2251)
12-21 13:11:16.655: W/System.err(12738):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
12-21 13:11:16.656: W/System.err(12738):    at android.app.ActivityThread.access$800(ActivityThread.java:144)
12-21 13:11:16.656: W/System.err(12738):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
12-21 13:11:16.656: W/System.err(12738):    at android.os.Handler.dispatchMessage(Handler.java:102)
12-21 13:11:16.656: W/System.err(12738):    at android.os.Looper.loop(Looper.java:135)
12-21 13:11:16.656: W/System.err(12738):    at android.app.ActivityThread.main(ActivityThread.java:5221)
12-21 13:11:16.656: W/System.err(12738):    at java.lang.reflect.Method.invoke(Native Method)
12-21 13:11:16.656: W/System.err(12738):    at java.lang.reflect.Method.invoke(Method.java:372)
12-21 13:11:16.656: W/System.err(12738):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
12-21 13:11:16.656: W/System.err(12738):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
12-21 13:11:16.656: W/System.err(12738): Caused by: java.lang.NullPointerException: Attempt to invoke interface method 'void android.bluetooth.IBluetoothPan.setBluetoothTethering(boolean)' on a null object reference
12-21 13:11:16.656: W/System.err(12738):    at android.bluetooth.BluetoothPan.setBluetoothTethering(BluetoothPan.java:337)
12-21 13:11:16.656: W/System.err(12738):    ... 17 more

私のBluetoothTetheringActivityでは、私のonCreateメソッドはメソッドを呼び出しますturnBluetoothTetheringOn

先に進み、デバッグ モード (私は Eclipse Luna を使用しています) に入り、android.bluetooth.BluetoothPan.setBluetoothTetheringメソッドに入ったときに興味深いことを発見しました: クラス変数mPanServiceは nullでした。コードが への参照を明示的に使用しているため、これは奇妙ですmPanService。のコードは次のandroid.bluetooth.BluetoothPan.setBluetoothTetheringとおりです。

public void setBluetoothTethering(boolean value) {
    if (DBG) log("setBluetoothTethering(" + value + ")");
    try {
        mPanService.setBluetoothTethering(value);
    } catch (RemoteException e) {
        Log.e(TAG, "Stack:" + Log.getStackTraceString(new Throwable()));
    }
}

このコードがどれほど最新のものかはわかりませんが、grepcode.com というサイトにBluetoothPanのコードのページがあります: android.bluetooth.BluetoothPan。このコードでmPanServiceは、 と呼ばれmServiceます。

BluetoothPanを呼び出す前に、のクラス変数mPanServiceが実際のオブジェクトを参照していることを確認するにはどうすればよいsetBluetoothTetheringですか?

私は正しい質問をしているわけではないかもしれないので、私の質問を言い換えることについて建設的な批判をいただければ幸いです。

4

1 に答える 1