Виталий Антипов
Виталий АнтиповAug. 18, 2017, 10:40 a.m.

Проблемы с памятью

Добрый день!

В процессе написания программки для Android на QML столкнулся со следующей проблемой - при открытии новых окон посредством StackView.push(), листинге элементов SwipeView и т.п. постоянно растет потребление памяти приложением. При опробовании на смартфоне постоянным открыванием новых окон добился выделения памяти приложению 800+ Мб, а далее система прибила мой процесс по причине отсутствия свободной памяти. Я понимаю, что за каждый объект нужно платить, но не понимаю, почему использованные неактивные объекты продолжают висеть в кэше (где сборщик мусора?). Поэтому, если можно, прошу разъяснить проблему и рассказать как в QML правильно работать с памятью.
P.S. Код не выкладываю, ибо очень большой. Структурно он выглядит так:
ApplicationWindow {
...
property int i: 0
property int k: 0

TextField{
id: textField
}
Button{
onClicked: k = textField.text
stackView.push(item1)
}

StackView{
id: stackView
...
Item{
id: item1
Component.onComplited: {
i = i + 1
}
SwipeView{
Item{
...
}
Item{
...
Button{
onClicked: {
if(i<=k){
stackView.push(item1)
} else {stackView.push(item2)}
}
}
}

Item{
id: item2
...
}

}
}
We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

8
Evgenii Legotckoi
  • Aug. 19, 2017, 7:47 a.m.
  • The answer was marked as a solution.

Добрый день!
При работе со StackView, когда вы делаете push страниц, они постоянно добавляются и добавляются. Они не должны в данном случае удаляться, если вы просто пушите страницы в StackView. Сборщик мусора считает, что страницы используются, просто они не видны в какой-то момент времени, они находятся в StackView, но не отображаются пользователю, поскольку StackView одновременно показывает только одну страницу, но может хранить в себе много страниц. Чтобы убрать страницы из StackView их нужно удалить через метод pop(), тогда и сборщик мусора освободит память.

Скорее всего аналогичная ситуация и со SwipeView. Предусмотрите механизм удаления ненужных страниц.

    Виталий Антипов
    • Aug. 20, 2017, 7:46 a.m.

    Огромное спасибо! Метод pop() отлично работает, память освобождается.

      Виталий Антипов
      • Aug. 20, 2017, 9:19 a.m.

      Небольшое дополнение в тему.  Я пошел по следующему пути: вызвал метод pop() непосредственно перед push(), т.е. удаляю из стека StackView ранее инициированные объекты, а затем вызываю нужный. Память как и задумано очищается, но возникает баг - во время загрузки вызванной странички за доли секунды появляются и исчезают все ранее вызываемые странички. Визуально выглядит очень неприятно.

      Нашел другой более простой путь. Есть метод replace(), которым можно заменять странички. Например stackView.replace(item1,item2) заменит первую страничку на вторую, при этом количество элементов в стеке останется = 1, а память так же отлично будет чиститься. И отсутствует описанный выше баг.

        А ну да. Есть там и такой метод replace(). А вот с появлением других страничек - это странно. Скорее всего баг в отрисовке. (я такую проблему видел с QWidget в определённых условиях). Какую ОС и вверсию Qt используете?

          Виталий Антипов
          • Aug. 21, 2017, 4:46 a.m.

          Windows 10, Qt 5.9, 5.10alfa.

            Ясно. Ну альфу оставим в покое, о том нет смысла думать, она же альфа. А вот про Qt 5.9 возьму на заметку.

              Виталий Антипов
              • Aug. 21, 2017, 5:28 a.m.
              https://giphy.com/gifs/3owvJTtyV8rns0KtC8/html5
              Вот так это выглядит в Qt 5.9.1

                Ну да. не очень-то хорошо выглядит.

                  Comments

                  Only authorized users can post comments.
                  Please, Log in or Sign up
                  AD

                  C ++ - Test 004. Pointers, Arrays and Loops

                  • Result:50points,
                  • Rating points-4
                  m

                  C ++ - Test 004. Pointers, Arrays and Loops

                  • Result:80points,
                  • Rating points4
                  m

                  C ++ - Test 004. Pointers, Arrays and Loops

                  • Result:20points,
                  • Rating points-10
                  Last comments
                  i
                  innorwallNov. 14, 2024, 12:07 p.m.
                  Circuit switching and packet data transmission networks Angioedema 1 priligy dapoxetine
                  i
                  innorwallNov. 14, 2024, 11:42 a.m.
                  How to Copy Files in Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                  i
                  innorwallNov. 14, 2024, 9:09 a.m.
                  Qt/C++ - Tutorial 068. Hello World using the CMAKE build system in CLion ditropan pristiq dosing With the Yankees leading, 4 3, Rivera jogged in from the bullpen to a standing ovation as he prepared for his final appearance in Chicago buy priligy pakistan
                  i
                  innorwallNov. 14, 2024, 4:05 a.m.
                  EVILEG-CORE. Using Google reCAPTCHA 2001; 98 29 34 priligy buy
                  i
                  innorwallNov. 14, 2024, 4 a.m.
                  PyQt5 - Lesson 007. Works with QML QtQuick (Signals and slots) priligy 30mg Am J Obstet Gynecol 171 1488 505
                  Now discuss on the forum
                  i
                  innorwallNov. 14, 2024, 3:39 a.m.
                  добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                  i
                  innorwallNov. 11, 2024, 10:55 a.m.
                  Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                  9
                  9AnonimOct. 25, 2024, 9:10 a.m.
                  Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                  Follow us in social networks