调用公共方法会导致NullPointerException - Android

时间:2013-04-05 08:21:07

标签: java android

啊,嘿大家,我只是想问一下我正在创建的程序中的问题是什么。这是代码段

PlayActivity.class

//more codes here
 public void stFLabel(int numFace, Context ct) {

    try {
        if(numFace > 0)
            faceLebel.setText("Face Hint : I See You Human");
        else
            faceLebel.setText("Face Hint : Where Are You?");
    }
    catch(NullPointerException e)
    {
        e.printStackTrace();
            Log.d(TAG, "stFLabel Has Error");
        }
    }
//more codes here

*的 CameraPreview.class *

//More codes
...
PlayActivity pacT = new PlayActivity();
...
//More Codes
..
public void pausy(int numFace) {
pacT.stFLabel(numFace, mContext);
}

logcat的

04-05 16:11:26.150: D/FaceDetection(27929): face detected: 1 Face 1 Location X: 65Y: -1
04-05 16:11:26.150: W/System.err(27929): java.lang.NullPointerException
04-05 16:11:26.150: W/System.err(27929):    at com.delihente.faceplay.PlayActivity.stFLabel(PlayActivity.java:90)
04-05 16:11:26.150: W/System.err(27929):    at com.delihente.faceplay.CameraPreview.pausy(CameraPreview.java:62)
04-05 16:11:26.150: W/System.err(27929):    at com.delihente.faceplay.CameraPreview$1.onFaceDetection(CameraPreview.java:53)
04-05 16:11:26.150: W/System.err(27929):    at android.hardware.Camera$EventHandler.handleMessage(Camera.java)
04-05 16:11:26.150: W/System.err(27929):    at android.os.Handler.dispatchMessage(Handler.java)
04-05 16:11:26.150: W/System.err(27929):    at android.os.Looper.loop(Looper.java)
04-05 16:11:26.150: W/System.err(27929):    at android.app.ActivityThread.main(ActivityThread.java)
04-05 16:11:26.150: W/System.err(27929):    at java.lang.reflect.Method.invokeNative(Native Method)
04-05 16:11:26.150: W/System.err(27929):    at java.lang.reflect.Method.invoke(Method.java:511)
04-05 16:11:26.150: W/System.err(27929):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java)
04-05 16:11:26.150: W/System.err(27929):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java)
04-05 16:11:26.150: W/System.err(27929):    at dalvik.system.NativeStart.main(Native Method)
04-05 16:11:26.150: D/(27929): stFLabel Has Error

更多信息:

PlayAcvitiy.class extends Activity (Main Class)
CameraPreview.class - The camera preview class provided by google android development
faceLebel = TextView on PlayAcvitiy.class
mContext = PlayActivity.class Context

我想知道导致NullPointerException的原因(修复会更好), 我已经阅读了近3页关于我的问题的谷歌搜索,但没有一个帮助我。 并且,请不要提及将方法更改为静态,因为它不能是因为它在CameraPreview.class检测/取消检测面时更改了TextView标签。 在此先感谢!

编辑:我在这里也读了很多相关的问题,但似乎都没有帮助

编辑2:解决问题,感谢所有人,特别是对PrafulBhatnagar,我了解到在主要活动中使用方法需要对其上下文的引用。谢谢大家!

3 个答案:

答案 0 :(得分:1)

NullPointerException的唯一原因是,

faceLebelstFLabel()方法中 Null

请确保您的faceLebel使用与您当前活动布局xml相同的ID。

另外,请确保您已声明setContentView(<R.layout.xml_File_Name>);在oncreate()

之后的super.onCreate().活动中

<强>更新

我怀疑在 CameraPreview.class 中调用您的方法stFLabel()。因为你不能像PlayActivity pacT = new PlayActivity();

那样创建Activity的构造函数

您必须使用Context of Activity来调用此方法。

答案 1 :(得分:0)

在调用set label

之前,检查faceLeble是否如下所示启动
faceLebel = (TextView)findViewById(R.id.txtViewId);

答案 2 :(得分:0)

在android中你永远不应该自己创建Activity对象..

当您从应用程序托盘启动应用程序时,系统会为启动器Activity创建对象并启动它。如果我们想要从一个屏幕转到另一个屏幕,我们使用startActivity(),此处系统再次创建Activity的对象..

因此,通常系统会创建Activity的对象并调用其生命周期方法,如onCreate(), onStart()等。我们使用这些生命周期回调来初始化/取消初始化Activity的状态.. < / p>

您的代码中的问题是您尝试自己创建Activity对象;所以现在有两个实例由系统创建,其中所有状态都已初始化,一个由代码创建,其中类的状态尚未初始化,因为没有调用生命周期方法因此NullPointerException。 / p>

您可以使用以下代码修复此错误:

((PlayActivity)mContext).stFLabel(numFace, mContext); ...假设mContext存储了对PlayActivity的引用

希望它有助于......