Как исправить исключение нулевого указателя Firebase Auth - PullRequest
0 голосов
/ 06 октября 2019

Я пытаюсь получить и отобразить имя пользователя от текущего аутентифицированного пользователя с FirebaseAuth, но приложение вылетает с NullPointerException

Я попытался отобразить user.getDisplayName () в консоле, а его нетNull

ImageView profilePicView = findViewById(R.id.profile_pic);
        TextView nameView = findViewById(R.id.name);
        TextView emailView = findViewById(R.id.email);

        FirebaseUser user = FirebaseAuth.getInstance().getCurrentUser();
        if (user != null) {
            if (user.getDisplayName() != null) {
                System.out.println("------------------------------user display name : " + user.getDisplayName());
                nameView.setText(user.getDisplayName());
            }

            if (user.getEmail() != null) {
                emailView.setText(user.getEmail());
            }

            if (user.getPhotoUrl() != null) {
                Glide.with(this)
                        .load(user.getPhotoUrl())
                        .into(profilePicView);
            }
        }

Вот ошибка стека

I/System.out: ------------------------------user display name : Mohammed Elmahdi Bechlaghem
D/AndroidRuntime: Shutting down VM
E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.megadevbrain.ranahna, PID: 20913
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.megadevbrain.ranahna/com.megadevbrain.ranahna.Navigation}: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.TextView.setText(java.lang.CharSequence)' on a null object reference
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3121)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3264)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1955)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:214)
        at android.app.ActivityThread.main(ActivityThread.java:7076)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:965)
     Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.TextView.setText(java.lang.CharSequence)' on a null object reference
        at com.megadevbrain.ranahna.Navigation.onCreate(Navigation.java:52)
        at android.app.Activity.performCreate(Activity.java:7327)
        at android.app.Activity.performCreate(Activity.java:7318)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1275)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3101)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3264) 
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78) 
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108) 
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1955) 
        at android.os.Handler.dispatchMessage(Handler.java:106) 
        at android.os.Looper.loop(Looper.java:214) 
        at android.app.ActivityThread.main(ActivityThread.java:7076) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:965) 
I/Process: Sending signal. PID: 20913 SIG: 9
Process 20913 terminated.

Ответы [ 3 ]

0 голосов
/ 06 октября 2019

Вы должны использовать Thread в своем методе, который вызывает объект.

0 голосов
/ 06 октября 2019

Либо переменная nameView, либо emailView имеет значение null. Пожалуйста, проверьте, что R.id.name и R.id.email являются действительными TextView в текущем представлении xml.

0 голосов
/ 06 октября 2019

Нулевой указатель, попробуйте сказать, что ваш Textview является нулевым. Это может произойти, потому что findviewbyid не совпадает с правильным в вашем XML. Убедитесь, что ваш идентификатор соответствует вашему XML и Java-файлу .Java

...