Throwing OutOfMemoryError "Не удалось выделить 28-байтовое распределение с 4000 свободных байтов и 3 КБ до OOM" - PullRequest
0 голосов
/ 27 августа 2018

Ошибки при сбое приложения

08-27 23:32:33.714 1178-1223/com.statusstock.wallpaperhd I/art: Clamp target GC heap from 398MB to 384MB
08-27 23:32:33.715 1178-1223/com.statusstock.wallpaperhd I/art: Alloc concurrent mark sweep GC freed 9(288B) AllocSpace objects, 0(0B) LOS objects, 0% free, 382MB/384MB, paused 533us total 58.639ms
    Forcing collection of SoftReferences for 3MB allocation
    Starting a blocking GC Alloc
08-27 23:32:33.766 1178-1223/com.statusstock.wallpaperhd I/art: Clamp target GC heap from 398MB to 384MB
    Alloc concurrent mark sweep GC freed 3(96B) AllocSpace objects, 0(0B) LOS objects, 0% free, 382MB/384MB, paused 439us total 51.432ms
08-27 23:32:33.766 1178-1223/com.statusstock.wallpaperhd W/art: Throwing OutOfMemoryError "Failed to allocate a 3686412 byte allocation with 1976816 free bytes and 1930KB until OOM"
08-27 23:32:33.766 1178-1223/com.statusstock.wallpaperhd D/skia: --- decoder->decode returned false

Это приложение для обоев, которое отображает изображения в виде сетки с помощью Picasso, получая URL-адрес изображения из базы данных. Если щелкнуть изображение, оно открывается в новом действии с помощью Picasso и Firebase. Но когда я запускаю свое приложение, оно занимает слишком много памяти и приложение вылетает после использования в течение нескольких минут. Я использовал android: hardwareAccelerated = "false" и android: largeHeap = "true", но они не работают.

Код:

Viewholder.java

import ...

public class ViewHolder extends RecyclerView.ViewHolder {

    View mView;

    public ViewHolder(final View itemView) {
        super(itemView);

        mView = itemView;

        itemView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                mClickListener.onItemClick(v, getAdapterPosition());
            }
        });

        itemView.setOnLongClickListener(new View.OnLongClickListener() {
            @Override
            public boolean onLongClick(View v) {

                mClickListener.onItemLongClick(v, getAdapterPosition());
                return true;
            }
        });

    }


    public void setDetails(Context ctx, String image){


        ImageView mImageTv = mView.findViewById(R.id.rImageView);

        Picasso.get().load(image).into(mImageTv);

    }


    private ViewHolder.ClickListener mClickListener;

    public interface ClickListener{

        void onItemClick(View view, int position);
        void onItemLongClick(View view, int position);

    }

    public void setOnclickListener(ViewHolder.ClickListener clickListener){

        mClickListener = clickListener;

    }


}

Фрагменты, показывающие обои в виде сетки

public class HDFragment extends Fragment {

    RecyclerView mRecyclerView;
    FirebaseDatabase mFirebaseDatabase;
    DatabaseReference mRef;


    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_hd, container, false);


        mRecyclerView = view.findViewById(R.id.recyclerView_hd);
        mRecyclerView.setHasFixedSize(true);


        mRecyclerView.setLayoutManager(new GridLayoutManager(getActivity(), 3));


        mFirebaseDatabase = FirebaseDatabase.getInstance();
        mRef = mFirebaseDatabase.getReference("New");

        FirebaseRecyclerAdapter<Model, ViewHolder> firebaseRecyclerAdapter = new FirebaseRecyclerAdapter<Model, ViewHolder>(Model.class, R.layout.row, ViewHolder.class, mRef) {
            @Override
            protected void populateViewHolder(ViewHolder viewHolder, Model model, int position) {

                viewHolder.setDetails(getActivity().getApplicationContext(), model.getImage());

            }

            @Override
            public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {


                ViewHolder viewHolder = super.onCreateViewHolder(parent, viewType);
                viewHolder.setOnclickListener(new ViewHolder.ClickListener() {
                    @Override
                    public void onItemClick(View view, int position) {

                        String mImage = getItem(position).getImage();


                        Intent intent = new Intent(view.getContext(), PostDetailsActivity2.class);

                        intent.putExtra("image", mImage);
                        startActivity(intent);


                    }

                    @Override
                    public void onItemLongClick(View view, int position) {


                    }
                });


                return viewHolder;
            }
        };


        mRecyclerView.setAdapter(firebaseRecyclerAdapter);


        return view;
    }
}

FullImage Activity показывает изображение во весь экран при нажатии

mImageTv = findViewById(R.id.full_imageView1);

        String image = getIntent().getStringExtra("image");


        Picasso.get().load(image).fit().centerCrop().memoryPolicy(MemoryPolicy.NO_CACHE).into(mImageTv);

Пожалуйста, помогите .. Спасибо

Ответы [ 2 ]

0 голосов
/ 27 августа 2018

Вы пытаетесь загрузить большое изображение, уменьшить разрешение изображения или использовать представление, которое обрабатывает большие изображения, например this .

0 голосов
/ 27 августа 2018

Если вам действительно нужно больше памяти, вы можете установить в Манифесте этот атрибут для Приложения, которое может решить проблему (возможно):

android:largeHeap="true"

хотя это не бесплатно, как вы можете прочитать в этом посте: Каковы преимущества установки для параметра largeHeap значения true?

...