0

電話から取得したデータをサービスから読み取り、TextView に表示するために、サービスをアクティビティにバインドしたいと考えています。

以下のコードを参照してください: Facts()method は、 MethodmServiceを呼び出した後に null であってはならない参照を使用しますが、null です。StartServiceFacts

tFacts.setText(Onfacts)ただし、別のボタンでメソッドを呼び出すと、問題なく動作します。では、メソッドでサービスにバインドできないのはなぜonCreateですか?追加のボタンの使用を避けるために、どうすればそれを達成できますか?

@Override
protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.handsetdetailsactivity);
    mConnection = new ConnectionClass();
    tFacts = (TextView) findViewById(R.id.tHandsetDtails);
    Intent intent = new Intent(HandsetDetailsActivity.this, 
        ServiceDeviceFacts.class);
    startService(intent);
    StartServiceFacts();
    tFacts.setText(Facts());
}

void StartServiceFacts() {
    Intent intent = new Intent(this, ServiceDeviceFacts.class);
    try {
        bindService(intent, mConnection, Context.BIND_AUTO_CREATE);
    } catch (Exception ex) {
        Log.e("Exception in the service", ex.toString());
    }
    Log.e("mBound value", mBound + "");
}

private class ConnectionClass implements ServiceConnection {

    @Override
    public void onServiceConnected(ComponentName className, IBinder service) {
        ServiceBinder binder = (ServiceBinder) service;
        mService = binder.getService();
        mBound = true;
    }

    @Override
    public void onServiceDisconnected(ComponentName arg0) {
        mBound = false;
    }
};

ログの猫のメッセージ エラー:

10-07 11:41:28.007: E/AndroidRuntime(24964): FATAL EXCEPTION: main
10-07 11:41:28.007: E/AndroidRuntime(24964): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.testma/com.testma.activities.HandsetDetailsActivity}: java.lang.NullPointerException
10-07 11:41:28.007: E/AndroidRuntime(24964):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1651)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at android.app.ActivityThread.access$1500(ActivityThread.java:117)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at android.os.Handler.dispatchMessage(Handler.java:99)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at android.os.Looper.loop(Looper.java:130)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at android.app.ActivityThread.main(ActivityThread.java:3687)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at java.lang.reflect.Method.invokeNative(Native Method)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at java.lang.reflect.Method.invoke(Method.java:507)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at dalvik.system.NativeStart.main(Native Method)
10-07 11:41:28.007: E/AndroidRuntime(24964): Caused by: java.lang.NullPointerException
10-07 11:41:28.007: E/AndroidRuntime(24964):    at com.testma.activities.HandsetDetailsActivity.Facts(HandsetDetailsActivity.java:81)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at com.testma.activities.HandsetDetailsActivity.onCreate(HandsetDetailsActivity.java:36)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
10-07 11:41:28.007: E/AndroidRuntime(24964):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615)
10-07 11:41:28.007: E/AndroidRuntime(24964):    ... 11 more
4

1 に答える 1

1

a へのバインドServiceAsynchronous操作です。そのため、 を呼び出した直後にサービス指向の操作を実行することはできませんStartServiceFacts()

でonServiceConnectedメソッドが呼び出されるまで待つ必要があります。ConnectionClassこれにより、 とのバインドが確認されActivityます。

ボタンの謎について!ボタンを押したときに正常に動作する理由は、ボタンのonClickが発生する前にサービスが既にバインドされているためです。

于 2013-10-07T10:30:50.720 に答える