java - 单击 AlertDialog 的“肯定”按钮时获取 'E/AndroidRuntime: Error reporting crash android.os.TransactionTooLargeException'

标签 java android facebook-graph-api firebase facebook-android-sdk

我收到此错误:

E/AndroidRuntime: Error reporting crash android.os.TransactionTooLargeException

还有这个:

java.lang.StackOverflowError: stack size 8MB

运行下面给定的代码时:

    mAuthListener = new FirebaseAuth.AuthStateListener() {
                @Override
                public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) {
                    final FirebaseUser user = firebaseAuth.getCurrentUser();
                    if (user != null) {
                        // User is signed in

                        if (isFacebookLoggedIn()) {

                            if (dialog == null) {

                                final AlertDialog.Builder builder = new AlertDialog.Builder(SignUpActivity.this);

                                LayoutInflater inflater = (LayoutInflater) getBaseContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
                                View alertDialogView = inflater.inflate(R.layout.choose_unique_name_dialog, null);
                                uniqueUserName = (EditText) alertDialogView.findViewById(R.id.uniqueUserName);
                                usernameChoosen = (TextView) alertDialogView.findViewById(R.id.usernameChoosen);
                                usernameWarning = (TextView) alertDialogView.findViewById(R.id.usernameWarning);

                                usernameChoosen.setVisibility(View.INVISIBLE);
                                usernameWarning.setVisibility(View.INVISIBLE);

                                builder.setTitle("Choose a unique username");
                                builder.setView(alertDialogView);
                                builder.setPositiveButton("Continue", new DialogInterface.OnClickListener() {
                                    @Override
                                    public void onClick(DialogInterface dialogInterface, int i) {

                                    }
                                });
                                dialog = builder.create();
                            }
                            dialog.show();
                            dialog.getButton(AlertDialog.BUTTON_POSITIVE).setOnClickListener(new View.OnClickListener() {
                                @Override
                                public void onClick(View v) {
                                    wantToCloseDialog = false;
                                    //Do stuff, possibly set wantToCloseDialog to true then...
                                    if (uniqueUserName.getText().toString().isEmpty()) {

                                        Toast.makeText(getBaseContext(), "Please choose a unique username", Toast.LENGTH_LONG).show();
                                        wantToCloseDialog = false;
                                    } else {

                                        mDatabase.child("unique-usernames").addValueEventListener(new ValueEventListener() {
                                            @Override
                                            public void onDataChange(DataSnapshot dataSnapshot) {
                                                if (dataSnapshot.getValue() != null) {
                                                    if (dataSnapshot.getValue().toString().contains(uniqueUserName.getText().toString())) {
                                                        Toast.makeText(getBaseContext(), uniqueUserName.getText().toString() + " is already taken", Toast.LENGTH_LONG).show();
                                                        usernameChoosen.setText(uniqueUserName.getText().toString());
                                                        wantToCloseDialog = false;
                                                    } else {

                                                        // error is happening on execution of this code

                                                        Log.d("signedIn", "onAuthStateChanged:signed_in:" + user.getUid());
                                                        mDatabase.child("users").child(user.getUid()).child("name").setValue(user.getDisplayName());
                                                        mDatabase.child("users").child(user.getUid()).child("imageUID").setValue(user.getPhotoUrl());
                                                        mDatabase.child("users").child(user.getUid()).child("uniqueUserName").setValue(uniqueUserName.getText().toString());
                                                        mDatabase.child("users").child(user.getUid()).child("followers").setValue("00");
                                                        mDatabase.child("users").child(user.getUid()).child("following").setValue("00");
                                                        mDatabase.child("unique-usernames").child(ts).setValue(uniqueUserName.getText().toString());
                                                        Intent mainIntent = new Intent(SignUpActivity.this, SplashActivity.class);
                                                        mainIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                                                        mainIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);
                                                        startActivity(mainIntent);
                                                        progressDialog.setMessage("Signing up...");
                                                        progressDialog.setCancelable(false);
                                                        progressDialog.show();
                                                        wantToCloseDialog = true;
                                                    }
                                                } else {
                                                    Log.d("signedIn", "onAuthStateChanged:signed_in:" + user.getUid());
                                                    mDatabase.child("users").child(user.getUid()).child("name").setValue(user.getDisplayName());
                                                    mDatabase.child("users").child(user.getUid()).child("imageUID").setValue(user.getPhotoUrl());
                                                    mDatabase.child("users").child(user.getUid()).child("uniqueUserName").setValue(uniqueUserName.getText().toString());
                                                    mDatabase.child("users").child(user.getUid()).child("followers").setValue("00");
                                                    mDatabase.child("users").child(user.getUid()).child("following").setValue("00");
                                                    mDatabase.child("unique-usernames").child(ts).setValue(uniqueUserName.getText().toString());
                                                    Intent mainIntent = new Intent(SignUpActivity.this, SplashActivity.class);
                                                    mainIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                                                    mainIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);
                                                    startActivity(mainIntent);
                                                    progressDialog.setMessage("Signing up...");
                                                    progressDialog.setCancelable(false);
                                                    progressDialog.show();
                                                    wantToCloseDialog = true;
                                                }
                                            }
                                            @Override
                                            public void onCancelled(DatabaseError databaseError) {
                                                Snackbar snackbar = Snackbar
                                                        .make(coordinatorLayout, databaseError.getMessage(), Snackbar.LENGTH_LONG);
                                                snackbar.show();
                                                wantToCloseDialog = false;
                                            }
                                        });
                                    }
                                    if(wantToCloseDialog)
                                        dialog.dismiss();
                                    //else dialog stays open. Make sure you have an obvious way to close the dialog especially if you set cancellable to false.
                                }
                            });
                        } else {

                            Log.d("signedIn", "onAuthStateChanged:signed_in:" + user.getUid());
                            mDatabase.child("users").child(user.getUid()).child("name").setValue(userName.getText().toString());
                            mDatabase.child("users").child(user.getUid()).child("uniqueUserName").setValue(uniqueUserName.getText().toString());
                            mDatabase.child("users").child(user.getUid()).child("followers").setValue("00");
                            mDatabase.child("users").child(user.getUid()).child("following").setValue("00");
                            mDatabase.child("unique-usernames").child(ts).setValue(uniqueUserName.getText().toString());
                            Intent mainIntent = new Intent(SignUpActivity.this, SplashActivity.class);
                            mainIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                            mainIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);
                            startActivity(mainIntent);
                            progressDialog.dismiss();

                        }
                    } else {
                        // User is signed out
                        Log.d("signedOut", "onAuthStateChanged:signed_out");
                    }
                    // ...
                }
            };

我以前从未见过任何此类错误,这就是为什么我不知道这里发生了什么。

请告诉我导致此错误的原因!

最佳答案

深入研究代码至少 10-12 次后,我发现了问题所在。

解决方案是在以下代码行中添加 .toString()user.getPhotoUrl():mDatabase.child("users")。 child(user.getUid()).child("imageUID").setValue(user.getPhotoUrl());

这个答案here给了我一点提示。谢谢qbix .

所以,现在已经解决了!

关于java - 单击 AlertDialog 的“肯定”按钮时获取 'E/AndroidRuntime: Error reporting crash android.os.TransactionTooLargeException',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40661629/

相关文章:

java - 如何在 Android 中打印 HashMap 中的所有键和值?

java - 谷歌任务 API : How can I find the TaskList of a Task?

javascript - Facebook Api 获取 friend 总数,但不是 friend 数据

facebook - 如何使用 Graph API 设置事件地点

java - 每1小时间隔将Servlet发布请求存储在文件中一分钟

java - 如何使用循环正确编写迷宫算法

java - 重载 APK 并创建自定义应用程序

facebook - iOS 和 Facebook 图形 API : Inconsistent authorize issues

java - 如何使用 java 中的 ActionListener 执行多个操作?

java - 使用 jna 和 CreateProcessW 时如何获取进程输出