【发布时间】:2021-07-01 12:30:50
【问题描述】:
实际上我解决了这个问题,但不知何故,经过几个小时的编码,现在它正在做同样的事情。 无法弄清楚出了什么问题,但每次执行 popup_durum 时它都会崩溃。当我将它添加到同一个类时,代码工作正常,但在单独的类中它崩溃了,我需要在每个页面中调用这个函数,任何帮助都将被提前获得。
This is the class i call
public class Antreman extends AppCompatActivity {
AlertDialog.Builder dialogBuilder;
Button AntremanaBasla,Cikis;
View popup_durum;
//Pop up----------------------------------------------------------------------------------------
public void AntremanSayfasi(){
dialogBuilder = new AlertDialog.Builder(this);
popup_durum = getLayoutInflater().inflate(R.layout.popup_durum,null);
AntremanaBasla = popup_durum.findViewById(R.id.basla);
Cikis = popup_durum.findViewById(R.id.cikis);
dialogBuilder.setView(popup_durum);
AlertDialog dialog = dialogBuilder.create();
dialog.show();
AntremanaBasla.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
}
});
Cikis.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
}
});
}
这是调用函数
public class Login extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
-----------
Antreman antreman = new Antreman();
logoImage = (ImageView) findViewById(R.id.logologin);
logoImage.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
antreman.AntremanSayfasi();
}
});
}
}
编辑 应用程序以此日志开始
2021-04-05 20:09:29.151 10257-10292/gymholix.assistx D/EGL_emulation: eglCreateContext: 0xa2085120: maj 3 min 0 rcv 3
2021-04-05 20:09:29.160 10257-10292/gymholix.assistx D/EGL_emulation: eglMakeCurrent: 0xa2085120: ver 3 0 (tinfo 0xa20832d0)
2021-04-05 20:09:29.168 10257-10292/gymholix.assistx E/eglCodecCommon: glUtilsParamSize: unknow param 0x00008cdf
2021-04-05 20:09:29.169 10257-10292/gymholix.assistx E/eglCodecCommon: glUtilsParamSize: unknow param 0x00008cdf
2021-04-05 20:09:29.169 10257-10292/gymholix.assistx E/eglCodecCommon: glUtilsParamSize: unknow param 0x00008824
2021-04-05 20:09:29.169 10257-10292/gymholix.assistx E/eglCodecCommon: glUtilsParamSize: unknow param 0x00008824
2021-04-05 20:09:29.202 10257-10292/gymholix.assistx D/EGL_emulation: eglMakeCurrent: 0xa2085120: ver 3 0 (tinfo 0xa20832d0)
2021-04-05 20:09:29.240 10257-10292/gymholix.assistx D/EGL_emulation: eglMakeCurrent: 0xa2085120: ver 3 0 (tinfo 0xa20832d0)
2021-04-05 20:09:29.252 10257-10292/gymholix.assistx D/EGL_emulation: eglMakeCurrent: 0xa2085120: ver 3 0 (tinfo 0xa20832d0)
2021-04-05 20:09:29.259 10257-10292/gymholix.assistx D/EGL_emulation: eglMakeCurrent: 0xa2085120: ver 3 0 (tinfo 0xa20832d0)
那么当它崩溃的时候日志是这样的
2021-04-05 20:09:29.259 10257-10292/gymholix.assistx D/EGL_emulation: eglMakeCurrent: 0xa2085120: ver 3 0 (tinfo 0xa20832d0)
2021-04-05 20:10:46.808 10257-10292/gymholix.assistx D/EGL_emulation: eglMakeCurrent: 0xa2085120: ver 3 0 (tinfo 0xa20832d0)
2021-04-05 20:10:52.673 10257-10257/gymholix.assistx D/AndroidRuntime: Shutting down VM
2021-04-05 20:10:52.674 10257-10257/gymholix.assistx E/AndroidRuntime: FATAL EXCEPTION: main
Process: gymholix.assistx, PID: 10257
java.lang.NullPointerException: Attempt to invoke virtual method 'android.content.pm.ApplicationInfo android.content.Context.getApplicationInfo()' on a null object reference
at android.content.ContextWrapper.getApplicationInfo(ContextWrapper.java:152)
at android.view.ContextThemeWrapper.getTheme(ContextThemeWrapper.java:157)
at androidx.appcompat.app.AlertDialog.resolveDialogTheme(AlertDialog.java:115)
at androidx.appcompat.app.AlertDialog$Builder.<init>(AlertDialog.java:313)
at gymholix.assistx.Antreman.AntremanSayfasi(Antreman.java:23)
at gymholix.assistx.Login$3.onClick(Login.java:76)
at android.view.View.performClick(View.java:6256)
at android.view.View$PerformClick.run(View.java:24701)
at android.os.Handler.handleCallback(Handler.java:789)
at android.os.Handler.dispatchMessage(Handler.java:98)
at android.os.Looper.loop(Looper.java:164)
at android.app.ActivityThread.main(ActivityThread.java:6541)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767)
【问题讨论】:
-
查看 Android Studio 中的 logcat 以了解导致崩溃的原因,如果您不知道这意味着什么或如何解决,请使用崩溃日志更新您的问题
-
在学习如何制作应用程序之前,先学习如何阅读日志developer.android.com/studio/debug/am-logcat分析堆栈跟踪developer.android.com/studio/debug/stacktraces并学习如何调试developer.android.com/studio/debug
-
Thnx edward 这是毕业项目,他们没有告诉任何关于 logcat 的信息,但现在学习它但仍然无法弄清楚为什么这条线在gymholix.assistx.Antreman.AntremanSayfasi(Antreman.java :23) line23--->dialogBuilder = new AlertDialog.Builder(this);
标签: java android class methods crash