我不知道怎么了,我的设备应用程序运行良好,但有时在日志(应用程序用户,会话,崩溃…通过某个服务跟踪)我看到应用程序崩溃(nullpointerexception),toast无法运行,因为活动变量为空。
第45行(populateCats()方法抛出异常nullPointerException)
package package.name;
import android.app.Activity;
import android.os.Bundle;
import android.support.v4.app.ListFragment;
import android.view.View;
import android.widget.ListView;
import android.widget.Toast;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import java.util.ArrayList;
public class CatsList extends ListFragment implements OnTaskCompleted {
Document doc;
MainActivity activity;
ArrayList<Cat> cats;
@Override
public void onListItemClick(ListView l, View v, int position, long id) {
super.onListItemClick(l, v, position, id);
Cat cat = cats.get(position);
//SOME CODE
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
new GetData(activity, this, false).execute(Jsoup.connect(MainActivity.url));
}
@Override
public void onAttach(Activity activity) {
super.onAttach(activity);
this.activity = (MainActivity) activity;
}
public void populateCats(){
if(doc == null)
{
Toast.makeText(activity, "Error....", Toast.LENGTH_SHORT).show();
return;
}
Toast.makeText(activity, "Success....", Toast.LENGTH_SHORT).show();
//SOME CODE
}
}
原木:
java.lang.NullPointerException
at android.widget.Toast.<init>(Toast.java:98)
at android.widget.Toast.makeText(Toast.java:254)
at PACKAGE_NAME.CatsList.populateCats(CatsList.java:64)
at PACKAGE_NAME.CatsList.taskCompleted(CatsList.java:92)
at PACKAGE_NAME.GetData.onPostExecute(GetData.java:61)
at PACKAGE_NAME.GetData.onPostExecute(GetData.java:12)
at android.os.AsyncTask.finish(AsyncTask.java:631)
at android.os.AsyncTask.access$600(AsyncTask.java:177)
at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4921)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794)
at dalvik.system.NativeStart.main(Native Method)
androidmanifect.xml还包含-android:configchanges=“keyboardhidden orientation screensize”
最佳答案
如果假设正确,getData类将异步调用populateCats()方法。这意味着在用户关闭活动时,异步过程仍在运行的地方存在多个交错。这将导致npe,因为如果正确实现了onattach/ondetach,那么在关闭活动后分离片段时,将清除活动引用。
作为一个好的实践,您应该始终检查每个活动引用或getActivity()调用的状态,并在执行任何其他指令之前验证它们是否不为空。