【问题标题】:NullPointer Exception in Service onStart when using ArrayList使用 ArrayList 时服务 onStart 中的 NullPointer 异常
【发布时间】:2011-11-23 12:51:32
【问题描述】:

当我尝试在我的 Service onStart 中使用 ArrayList 时收到以下异常。

谁能帮忙?

谢谢 格雷厄姆

问题似乎在这里

    @Override
public void onStart(Intent intent, int startid) {
Log.d(TAG, "onStart");
data = intent.getExtras();
ORIG = data.getString("originator");


Toast.makeText(this, "My Service Started with passed in value " + ORIG, Toast.LENGTH_LONG).show();
if(items.contains(ORIG)){
Log.d(TAG, "Element already exists exiting "); 
} else {
Log.d(TAG, "Adding Element");
    items.add(ORIG);

}

这是 LOGCAT 中引发的异常

    E/AndroidRuntime( 7496): FATAL EXCEPTION: main
E/AndroidRuntime( 7496): java.lang.RuntimeException: Unable to start service com    .example.MyService@4052eed0 with Intent { cmp=com.example/.MyService (has extras) }: java.lang.NullPointerException
E/AndroidRuntime( 7496):        at android.app.ActivityThread.handleServiceArgs(    ActivityThread.java:2056)
E/AndroidRuntime( 7496):        at android.app.ActivityThread.access$2800(Activi    tyThread.java:117)
E/AndroidRuntime( 7496):        at android.app.ActivityThread$H.handleMessage(Ac    tivityThread.java:998)
E/AndroidRuntime( 7496):        at android.os.Handler.dispatchMessage(Handler.ja    va:99)
E/AndroidRuntime( 7496):        at android.os.Looper.loop(Looper.java:123)
E/AndroidRuntime( 7496):        at android.app.ActivityThread.main(ActivityThrea    d.java:3691)
E/AndroidRuntime( 7496):        at java.lang.reflect.Method.invokeNative(Native    Method)
E/AndroidRuntime( 7496):        at java.lang.reflect.Method.invoke(Method.java:507)
E/AndroidRuntime( 7496):        at com.android.internal.os.ZygoteInit$MethodAndA    rgsCaller.run(ZygoteInit.java:847)
E/AndroidRuntime( 7496):        at com.android.internal.os.ZygoteInit.main(Zygot    eInit.java:605)
E/AndroidRuntime( 7496):        at dalvik.system.NativeStart.main(Native Method)

E/AndroidRuntime( 7496): Caused by: java.lang.NullPointerException
E/AndroidRuntime( 7496):        at com.example.MyService.onStart(MyService.java:54)
E/AndroidRuntime( 7496):        at android.app.Service.onStartCommand(Service.ja    va:428)
E/AndroidRuntime( 7496):        at android.app.ActivityThread.handleServiceArgs(    ActivityThread.java:2043)
E/AndroidRuntime( 7496):        ... 10 more
W/ActivityManager( 2696):   Force finishing activity com.example/.ServicesDemo
E/        ( 2696): Dumpstate > /data/log/dumpstate_app_error
I/dumpstate( 7586): begin
W/ActivityManager( 2696): Activity pause timeout for HistoryRecord{408759b0 com.    example/.ServicesDemo}

调用我的服务的活动

package com.example;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;

public class ServicesDemo extends Activity implements OnClickListener {
  private static final String TAG = "ServicesDemo";
  Button buttonStart, buttonStop;
  EditText Input;
  String x = "";  //test pass to my service

  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    buttonStart = (Button) findViewById(R.id.buttonStart);
    buttonStop = (Button) findViewById(R.id.buttonStop);
    Input = (EditText) findViewById(R.id.INPUT);
    buttonStart.setOnClickListener(this);
    buttonStop.setOnClickListener(this);

  }

  public void onClick(View src) {
    switch (src.getId()) {
    case R.id.buttonStart:
      Log.d(TAG, "onClick: starting srvice");
      Intent dataIntent = new Intent(ServicesDemo.this, MyService.class);
      x = Input.getText().toString(); 
      dataIntent.putExtra("originator", x);
      startService(dataIntent);

      break;

    case R.id.buttonStop:

      Log.d(TAG, "onClick: stopping srvice");
      //implicit starting 
      stopService(new Intent(this, MyService.class));
      break;
    }
  }


public static String getTag() {
return TAG;
}
}

我尝试使用问题的服务在 onStart 中

package com.example;


import java.util.ArrayList;

import android.app.Service;
import android.content.Intent;
import android.os.Bundle;
import android.os.IBinder;
import android.util.Log;
import android.widget.Toast;

public class MyService extends Service {

ArrayList<String> items;

public String ORIG = "";
private static final String TAG = "MyService";
public Bundle data = new Bundle();


@Override
public IBinder onBind(Intent intent) {
return null;
}


public static String getTag() {
return TAG;
}


@Override
public void onCreate() {
Toast.makeText(this, "My Service Created", Toast.LENGTH_LONG).show();
Log.d(TAG, "onCreate");


}

@Override
public void onDestroy() {
Toast.makeText(this, "My Service Stopped", Toast.LENGTH_LONG).show();
Log.d(TAG, "onDestroy");

}

@Override
public void onStart(Intent intent, int startid) {
Log.d(TAG, "onStart");
data = intent.getExtras();
ORIG = data.getString("originator");
Toast.makeText(this, "My Service Started with passed in value " + ORIG, Toast.LENGTH_LONG).show();
if(items.contains(ORIG)){
Log.d(TAG, "Element already exists exiting "); 
} else {
Log.d(TAG, "Adding Element");
    items.add(ORIG);

}


Thread initBkgdThread = new Thread(new Runnable() {
public void run() {
//print_result();
}
});
initBkgdThread.start();

}

public void print_result(String orig){
Log.d(TAG, "HELLO WORLD:" + orig);


}

}

【问题讨论】:

  • 您的服务中的项目是什么,我认为这与您的NPE有关。
  • 我没有看到你在哪里初始化列表。

标签: android service arraylist nullpointerexception


【解决方案1】:

看起来像数组列表 ArrayList 未初始化,因此您在服务 MyService 的 onCreate() 方法中得到 NullPointerException。

【讨论】:

  • 嗨,我发现我的代码中的问题可以更改如下,但我仍然得到 NullPointerException
  • public void onStart(Intent intent, int startid) { Log.d(TAG, "onStart");数据 = 意图.getExtras(); ORIG = data.getString("originator"); Log.d(TAG, "onCreate");线程 initBkgdThread = new Thread(new Runnable() { public void run() { print_result(ORIG); } }); initBkgdThread.start(); } public void print_result(String orig){ Log.d(TAG, "HELLO WORLD:" + orig); ArrayList 项 = null;字符串 toadd = orig.toString(); if(items.contains(toadd)){ Log.d(TAG, "元素已经存在退出"); } else { Log.d(TAG, "添加元素"); items.add(toadd);
  • public void onStart(Intent intent, int startid) { Log.d(TAG, "onStart");数据 = 意图.getExtras(); ORIG = data.getString("originator"); Log.d(TAG, "onCreate");线程 initBkgdThread = new Thread(new Runnable() { public void run() { print_result(ORIG); } }); initBkgdThread.start(); } public void print_result(String orig){ Log.d(TAG, "HELLO WORLD:" + orig); ArrayList 项 = null;字符串 toadd = orig.toString(); if(items.contains(toadd)){ Log.d(TAG, "元素已经存在退出"); } else { Log.d(TAG, "添加元素"); items.add(toadd);
  • @GrahamBright 你应该编辑你的帖子而不是粘贴代码作为评论。
【解决方案2】:

我没有看到你初始化 ArrayList。首先初始化数组然后使用它。其次,要牢记Activity的生命周期。

【讨论】:

    猜你喜欢
    • 2013-06-22
    • 2011-10-16
    • 2011-09-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-08-09
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多