Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/312.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 服务类空指针_Java_Android - Fatal编程技术网

Java 服务类空指针

Java 服务类空指针,java,android,Java,Android,我已经为我的网络连接创建了一个服务类,这样我的应用程序就可以创建一个连接,然后在整个程序中访问输入和输出流。我在第一个活动中实例化了服务类,但每当我尝试从服务类访问get方法时,都会得到一个null指针异常。奇怪的是,当我调试程序时,它没有得到这个错误 下面是获取代码的类: public class WaitingActivity extends Activity implements Runnable{ WaitingNetwork roleGetter; String role; int g

我已经为我的网络连接创建了一个服务类,这样我的应用程序就可以创建一个连接,然后在整个程序中访问输入和输出流。我在第一个活动中实例化了服务类,但每当我尝试从服务类访问get方法时,都会得到一个null指针异常。奇怪的是,当我调试程序时,它没有得到这个错误

下面是获取代码的类:

public class WaitingActivity extends Activity implements Runnable{
WaitingNetwork roleGetter;
String role;
int gotrole = 0;
Intent intent;



protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.waitingroom);   


    Thread thread = new Thread(this);
    thread.start();
    ProgressDialog dialog = ProgressDialog.show(WaitingActivity.this, "", 
            "Loading. Please wait...", true);
}
Networking mService;
boolean mBound = false;

@Override
protected void onStart() {
    super.onStart();
    // Bind to LocalService
    Intent intent = new Intent(this, Networking.class);
    bindService(intent, mConnection, Context.BIND_AUTO_CREATE);
}

@Override
protected void onStop() {
    super.onStop();
    // Unbind from the service
    if (mBound) {
        unbindService(mConnection);
        mBound = false;
    }
}

/** Called when a button is clicked (the button in the layout file attaches to
 * this method with the android:onClick attribute) */


/** Defines callbacks for service binding, passed to bindService() */
private ServiceConnection mConnection = new ServiceConnection() {

    @Override
    public void onServiceConnected(ComponentName className,
            IBinder service) {
        // We've bound to LocalService, cast the IBinder and get LocalService instance
        LocalBinder binder = (LocalBinder) service;
        mService = binder.getService();
        mBound = true;
    }

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


ObjectInputStream stream;
public void getStream(){
    stream = mService.getStateOis();
}

@Override
public void run() {

    getStream();

    roleGetter = new WaitingNetwork(stream);
    Thread fred = new Thread(roleGetter);
    fred.start();
以下是堆栈跟踪:

03-26 15:41:16.374: E/AndroidRuntime(1301): FATAL EXCEPTION: Thread-11
03-26 15:41:16.374: E/AndroidRuntime(1301): java.lang.NullPointerException
03-26 15:41:16.374: E/AndroidRuntime(1301):     at  com.DrawTastic.WaitingActivity.getStream(WaitingActivity.java:82)
03-26 15:41:16.374: E/AndroidRuntime(1301):     at com.DrawTastic.WaitingActivity.run(WaitingActivity.java:88)
03-26 15:41:16.374: E/AndroidRuntime(1301):     at java.lang.Thread.run(Thread.java:1019)
03-26 15:41:18.454: E/WindowManager(1301): Activity com.DrawTastic.WaitingActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@405320a0 that was originally added here
03-26 15:41:18.454: E/WindowManager(1301): android.view.WindowLeaked: Activity com.DrawTastic.WaitingActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@405320a0 that was originally added here
03-26 15:41:18.454: E/WindowManager(1301):  at android.view.ViewRoot.<init>(ViewRoot.java:258)
03-26 15:41:18.454: E/WindowManager(1301):  at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148)
03-26 15:41:18.454: E/WindowManager(1301):  at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
03-26 15:41:18.454: E/WindowManager(1301):  at android.view.Window$LocalWindowManager.addView(Window.java:424)
03-26 15:41:18.454: E/WindowManager(1301):  at android.app.Dialog.show(Dialog.java:241)
03-26 15:41:18.454: E/WindowManager(1301):  at android.app.ProgressDialog.show(ProgressDialog.java:107)
03-26 15:41:18.454: E/WindowManager(1301):  at android.app.ProgressDialog.show(ProgressDialog.java:90)
03-26 15:41:18.454: E/WindowManager(1301):  at com.DrawTastic.WaitingActivity.onCreate(WaitingActivity.java:33)
03-26 15:41:18.454: E/WindowManager(1301):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-26 15:41:18.454: E/WindowManager(1301):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
03-26 15:41:18.454: E/WindowManager(1301):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
03-26 15:41:18.454: E/WindowManager(1301):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
03-26 15:41:18.454: E/WindowManager(1301):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
03-26 15:41:18.454: E/WindowManager(1301):  at android.os.Handler.dispatchMessage(Handler.java:99)
03-26 15:41:18.454: E/WindowManager(1301):  at android.os.Looper.loop(Looper.java:123)
03-26 15:41:18.454: E/WindowManager(1301):  at android.app.ActivityThread.main(ActivityThread.java:3683)
03-26 15:41:18.454: E/WindowManager(1301):  at java.lang.reflect.Method.invokeNative(Native Method)
03-26 15:41:18.454: E/WindowManager(1301):  at java.lang.reflect.Method.invoke(Method.java:507)
03-26 15:41:18.454: E/WindowManager(1301):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
03-26 15:41:18.454: E/WindowManager(1301):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
03-26 15:41:18.454: E/WindowManager(1301):  at dalvik.system.NativeStart.main(Native Method)
03-26 15:41:16.374:E/AndroidRuntime(1301):致命异常:线程11
03-26 15:41:16.374:E/AndroidRuntime(1301):java.lang.NullPointerException
03-26 15:41:16.374:E/AndroidRuntime(1301):位于com.DrawTastic.WaitingActivity.getStream(WaitingActivity.java:82)
03-26 15:41:16.374:E/AndroidRuntime(1301):在com.DrawTastic.WaitingActivity.run(WaitingActivity.java:88)
03-26 15:41:16.374:E/AndroidRuntime(1301):在java.lang.Thread.run(Thread.java:1019)处
03-26 15:41:18.454:E/WindowManager(1301):活动com.DrawTastic.WaitingActivity已泄漏window com.android.internal.policy.impl.PhoneWindow$DecorView@405320a0原来是加在这里的
03-26 15:41:18.454:E/WindowManager(1301):android.view.WindowLeaked:Activity com.DrawTastic.WaitingActivity已泄漏window com.android.internal.policy.impl.PhoneWindow$DecorView@405320a0原来是加在这里的
03-26 15:41:18.454:E/WindowManager(1301):在android.view.ViewRoot.(ViewRoot.java:258)
03-26 15:41:18.454:E/WindowManager(1301):在android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148)
03-26 15:41:18.454:E/WindowManager(1301):在android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
03-26 15:41:18.454:E/WindowManager(1301):在android.view.Window$LocalWindowManager.addView(Window.java:424)
03-26 15:41:18.454:E/WindowManager(1301):在android.app.Dialog.show(Dialog.java:241)上
03-26 15:41:18.454:E/WindowManager(1301):在android.app.ProgressDialog.show(ProgressDialog.java:107)上
03-26 15:41:18.454:E/WindowManager(1301):在android.app.ProgressDialog.show(ProgressDialog.java:90)上
03-26 15:41:18.454:E/WindowManager(1301):位于com.DrawTastic.WaitingActivity.onCreate(WaitingActivity.java:33)
03-26 15:41:18.454:E/WindowManager(1301):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-26 15:41:18.454:E/WindowManager(1301):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
03-26 15:41:18.454:E/WindowManager(1301):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
03-26 15:41:18.454:E/WindowManager(1301):在android.app.ActivityThread.access$1500(ActivityThread.java:117)
03-26 15:41:18.454:E/WindowManager(1301):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
03-26 15:41:18.454:E/WindowManager(1301):在android.os.Handler.dispatchMessage(Handler.java:99)上
03-26 15:41:18.454:E/WindowManager(1301):在android.os.Looper.loop(Looper.java:123)
03-26 15:41:18.454:E/WindowManager(1301):位于android.app.ActivityThread.main(ActivityThread.java:3683)
03-26 15:41:18.454:E/WindowManager(1301):位于java.lang.reflect.Method.Invokenactive(本机方法)
03-26 15:41:18.454:E/WindowManager(1301):位于java.lang.reflect.Method.invoke(Method.java:507)
03-26 15:41:18.454:E/WindowManager(1301):位于com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
03-26 15:41:18.454:E/WindowManager(1301):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
03-26 15:41:18.454:E/WindowManager(1301):在dalvik.system.NativeStart.main(本机方法)

正如尼古拉斯指出的那样,这是一种竞赛条件

通过调用bindService(),您没有做任何积极的事情—您只是请求启动服务。只有在调用OnServiceConnection()时,服务才准备就绪


向服务中添加侦听器模式。在OnServiceConnection()期间激发现有侦听器,一旦发生这种情况,立即激发任何新侦听器。然后,在您的usage类收到该回调之前,不要进行任何服务调用,以表示服务已准备就绪。

这几乎肯定是一种竞争条件。在
onCreate(Bundle)
中启动一个线程,该线程希望
mService
引用某种类型的实例,但在绑定
服务之前(在
onStart()
中发生),不会填充该实例


我不确定,但是您的服务可以绑定到
onCreate(Bundle)
(特别是在启动
线程之前),还是可以在
onStart()
中启动线程(特别是在绑定
服务之后)?执行其中任何一项都会有所帮助,但最好的办法是使用某种侦听器模式,它利用回调(与android应用程序框架一样)。

线程在onCreate()中启动,服务在onStart()中绑定(onCreate之后),因此mService为null,没有异常stacktrace,我们能为您做的不多;听起来像是比赛条件。您需要向我们展示更多代码来帮助您,但我想,当您不进行调试时,您可以在绑定服务之前调用
getStateOis()
。调试时,在调用
getStateOis()
之前会绑定服务。在Networking类中发布getStateOis()方法中的一些代码。我想你的问题就在这里。NullPointer可能是最容易找到的错误,因为它告诉您正在尝试调用不存在或不正确的东西:直到OnServiceConnection()才填充它,因为bindService()是异步的,在创建服务时不会阻塞。更多信息,请参阅。