java - 每次下载数据时总和都会增加

标签 java android android-studio

我有一个购物车,当我从数据库下载数据时,我会对价格进行求和并显示用户必须支付的总金额。我面临的问题是,当我打开应用程序时,我的购物车是空的,因此在我添加 1 2 3 件商品并返回到购物 list 后,总和为零,然后当我打开时又返回到购物车购物车的总和 = 我最后一次总和的总和*2,如果我没记错的话,这是由于 onDataChange 造成的,因为它从数据集中获取价格并将价格添加到变量总和中,但这是错误的,因为它确实这样做了其一。

我是 Android 新手,所以我不明白为什么会发生这种情况,提前谢谢您。 示例:

清空购物车:总和 = 0 添加 2 件商品到购物车:总和 = 100 返 repo 物 list : 金额仍为 100 从购物列表返回到购物车,而不向列表中添加任何内容:现在总和为 200,有相同的 2 件商品。

代码:

    package com.example.ipill;

import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;


import android.content.Context;
import android.content.Intent;
import android.nfc.Tag;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.TextView;
import android.widget.Toast;
import com.firebase.ui.database.FirebaseRecyclerAdapter;
import com.google.firebase.database.DataSnapshot;
import com.google.firebase.database.DatabaseError;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
import com.google.firebase.database.Query;
import com.google.firebase.database.ValueEventListener;

import java.net.HttpCookie;
import java.util.ArrayList;
import java.util.List;
import java.util.Timer;
import java.util.TimerTask;


public class CartActivity extends AppCompatActivity implements  OnRemoveItemClickListener{

    private TextView total;
    private ImageButton removeFromCartt;
    private Button pay;
    private RecyclerView mResultList2;
    private DatabaseReference mUserDatabase;
    int i=0;
    public static int Totalprice=0;
    private UsersAdapter adapter;
    private ArrayList<Users_get> array_data = new ArrayList<>();
    final Handler handler = new Handler();
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_cart);
        mUserDatabase = FirebaseDatabase.getInstance().getReference("Cart");

        total          = findViewById(R.id.TotalPrice);
        total.setText(0+"");
        removeFromCartt = findViewById(R.id.removeFromCart);
        mResultList2    = findViewById(R.id.cartList);
        pay            = findViewById(R.id.pay);

        mResultList2.setHasFixedSize(true);
        mResultList2.setLayoutManager(new LinearLayoutManager(this));


        // Attach a listener to read the data at our posts reference
        mUserDatabase.addValueEventListener(new ValueEventListener() {


            @Override
            public void onDataChange(DataSnapshot dataSnapshot) {
                int flag=1;

                if (adapter == null) {
                    for (DataSnapshot childSnapshot : dataSnapshot.getChildren()) {
                        Users_get post = childSnapshot.getValue(Users_get.class);
                        array_data.add(new Users_get(post.getName(), post.getSurname(), post.getPrice(), childSnapshot.getKey()));
                        if(array_data!=null){
                            getTotalPrice(post.getPrice(),flag);
                        }
                    }
                    total.setText(Integer.toString(Totalprice)+"");
                    setAdapter();
                } else {
                    adapter.notifyDataSetChanged();
                }
            }

            @Override
            public void onCancelled(DatabaseError databaseError) {
                System.out.println("The read failed: " + databaseError.getCode());
            }

        });

        pay.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(CartActivity.this,FirebaseSearch.class);
                startActivity(intent);
                finish();
            }
        });
    }


    private void setAdapter() {
        adapter = new UsersAdapter(array_data,CartActivity.this);
        mResultList2.setAdapter(adapter);

    }

    public void getTotalPrice(Long price,int flag){
            if(flag==1)
            {
                Totalprice+=price;
            }
            if(flag==0)
            {
                Totalprice-=price;
            }

        System.out.println(Totalprice);
    }


    @Override
    public void onRemoveItemClicked(final int position) {
        int flag=0;
        FirebaseDatabase.getInstance().getReference("Cart").child(array_data.get(position).getKey()).removeValue();
        getTotalPrice(array_data.get(position).getPrice(),flag);
        if(Totalprice!=0){
            total.setText(Integer.toString(Totalprice)+"");
        }
        else if(mResultList2==null){
            Totalprice=0;
            total.setText(0+"");
        }
        array_data.remove(position);
        adapter.notifyItemRemoved(position);

    }


    @Override
    protected void onDestroy() {
        super.onDestroy();
        if(adapter !=null){
            adapter.removeListener();
        }
    }
}

最佳答案

您正在创建静态变量

public static int Totalprice=0;

如果您不希望在 Activity 之外使用static关键字,请删除它

如果您希望它在 Activity 之外,您可以将此变量重新初始化为 onCreate() 为 0

Totalprice=0;

关于java - 每次下载数据时总和都会增加,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60337436/

相关文章:

Java isNan 是如何工作的?

java - 观察者、可观察和可运行。为什么同步块(synchronized block)丢失了监视器?

java - 在类结构中找到正确的子类

java - 正确的。 over bar 的转义序列?

java - 阿拉伯语文本显示为 ???在安卓中

LINUX 中的 Android SDK Manager 代理设置

安卓工作室 :app:compileDebugJavaWithJavac package R does not exist

android - 发送不 protected 广播 com.motorola.motocare.INTENT_TRIGGER java.lang.Throwable

android - 使用不同的 asset .properties 进行调试和发布

java - 删除应用程序时是否删除与应用程序关联的共享首选项?