BlinCT
BlinCTApril 1, 2020, 8:09 p.m.

Утечка памяти при динамическом выделении

Всем привет.
Такой вопрос, в классе есть приватный метод, в который передаются некоторые данные

QSGGeometryNode *NavRect::lineNode(QPoint beginPoint , QPoint endPoint, QColor colorLine, QSGGeometryNode *oldNode)
{
    auto material = new QSGFlatColorMaterial;
    material->setColor(colorLine);

    if(!oldNode)
    {
        auto pNode = new QSGGeometryNode;
        auto pLineGeometry=new QSGGeometry(QSGGeometry::defaultAttributes_Point2D(), 2);
        pLineGeometry->setLineWidth(1);
        pLineGeometry->setDrawingMode(GL_LINES);

        pLineGeometry->vertexDataAsPoint2D()[0].set(beginPoint.x(), beginPoint.y());
        pLineGeometry->vertexDataAsPoint2D()[1].set(endPoint.x(), endPoint.y());

        pNode->setGeometry(pLineGeometry);
        pNode->setFlags(QSGNode::OwnsGeometry | QSGNode::OwnsMaterial);
        pNode->setMaterial(material);

        return pNode;
    }
    else
    {
        oldNode->setMaterial(material);
    }

    return oldNode;
}

Как тут видите в нем аж 3 new, то есть один возвращается в метод класса для дальнейшей работы, а вот другие 2 нет.
Как правильно разабратся с ними чтоыб указатели не плавали после выхода из метода?
Если их сделать мемберами в данном классе это вроде не избавляет от проблемы?
Спасибо.

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
  • April 2, 2020, 2:37 a.m.
  • (edited)

Привет.

Здесь не надо ничего такого делать, память здесь будет очищаться за счёт этой строчки

pNode->setFlags(QSGNode::OwnsGeometry | QSGNode::OwnsMaterial);

То есть ты берёшь владение материалом и геометрией на pNode, а сама pNode должна будет уничтожаться дальше в дереве объектов OpenGL, попутно уничтожая материал и геометрию. QML всё это предусматривает.

Если по какой-то причине всё-таки происходит утечка памяти, то значит косяк где-то в логике метода updatePaintNode

Для проверки можно сделать для всех этих классов наследников и переопределить деструктор с выводом qDebug, как сделано в этой статье для QStandardItem . Это позволит убедиться, что удаление всё-таки происходит.

    BlinCT
    • April 2, 2020, 3:35 a.m.

    Оки спасибо, сейчас проверю.

      BlinCT
      • April 2, 2020, 4:40 a.m.

      В общем все таки утечка есть, по причине логики метода где вызывается данная функция.
      Вот так она выглядит

      QSGNode *NavRect::updatePaintNode(QSGNode *oldNode, QQuickItem::UpdatePaintNodeData *updatePaintNodeData)
      {
          Q_UNUSED(updatePaintNodeData)
      
          QColor foreground = Qt::white;
          QColor background = Qt::black;
      
          auto width = boundingRect().width();
          auto height = boundingRect().height();
      
          if(hasFocus())
          {
              background = Qt::white;
              foreground = Qt::black;
          }
      
          setProperty("foreground", foreground);
          setProperty("background", background);
      
      
          if(!oldNode)
          {
              //! complete creation of objects and attaching them to a node, background color
              m_pBackgroundNode = window()->createRectangleNode();
              m_pBackgroundNode->setRect(boundingRect());
              m_pBackgroundNode->setColor(background);
      
              //! draw lines
              m_pNodeLineOne = lineNode(QPoint(0, 0), QPoint(width, 0), foreground);
              m_pNodeLineTwo = lineNode(QPoint(width, 0), QPoint(width, height), foreground);
              m_pNodeLineThree = lineNode(QPoint(width, height), QPoint(0, height), foreground);
              m_pNodeLineFour = lineNode(QPoint(0, height), QPoint(0, 0), foreground);
      
              m_pBackgroundNode->appendChildNode(m_pNodeLineOne);
              m_pBackgroundNode->appendChildNode(m_pNodeLineTwo);
              m_pBackgroundNode->appendChildNode(m_pNodeLineThree);
              m_pBackgroundNode->appendChildNode(m_pNodeLineFour);
      
              return m_pBackgroundNode;
          }
      
          //! if a node exists, update the background
          m_pBackgroundNode->setColor(background);
      
          //! updating lines
          m_pNodeLineOne = lineNode(QPoint(0, 0), QPoint(width, 0), foreground, m_pNodeLineOne);
          m_pNodeLineTwo = lineNode(QPoint(width, 0), QPoint(width, height), foreground, m_pNodeLineTwo);
          m_pNodeLineThree = lineNode(QPoint(width, height), QPoint(0, height), foreground, m_pNodeLineThree);
          m_pNodeLineFour = lineNode(QPoint(0, height), QPoint(0, 0), foreground, m_pNodeLineFour);
      
          return oldNode;
      }
      

      То есть при первом входе создаюется обьект и вызывается lineNode для создания линий, а потом когда уже нода существует то мы снова заходим в метод и опять делаем new.
      Так что вот с этим и проблема как раз.

        Evgenii Legotckoi
        • April 2, 2020, 4:50 a.m.
        • (edited)

        Проблема в том, что если нода уже была создана, то ты заново пересоздаешь ноды, а не перерисовываешь. Посмотри как сделано в этой статье QML - Урок 032. Создаём Custom QuickItem из C++ с использованием средств OpenGL

        Я не создаю там новые объекты, если oldNode существует, я перерисовываю ноду в уже существющих объектах. А ты просто создаешь каждый раз новые объекты m_pNodeLineOne, m_pNodeLineTwo, m_pNodeLineThree, m_pNodeLineFour если oldNode . Либо удаляй их, если они существуют и потом создавай новые, либо переопределяй некоторые свойства. Переопределение наверняка будет производительнее, чем создавать новые объекты.

        В общем тебе нужен ещё один метод, который будет менять точки, то есть менять геометрию.

          Evgenii Legotckoi
          • April 2, 2020, 4:53 a.m.
          • (edited)

          хотя, если вниметльно посмотреть на метод lineNode, то скорее всего проблема в том, что ты создаешь материал в начале метода. Старый скорее всего не удаляется, пока не была удалена нода, а просто заменяется, и остаётся висеть в памяти.

            BlinCT
            • April 3, 2020, 12:52 p.m.

            В общем я просто сделал вторйо метод который простог обнавляет цвет и материал, вроде сделал правильно.
            Но вот на эмбедеде есл ия быстро переключаюсь межуд обьектами они начали как бы мерцать, у меня предположение что я что то еще должен добавить в метод но не пойму что.

            QSGGeometryNode *NavRect::nonExistLineNode(QPoint beginPoint , QPoint endPoint, QColor colorLine, QSGGeometryNode *oldNode)
            {
                m_pMaterial = new QSGFlatColorMaterial;
                m_pMaterial->setColor(colorLine);
            
                if(!oldNode)
                {
                    m_pGeometryNode = new QSGGeometryNode;
                    m_pGeometry = new QSGGeometry(QSGGeometry::defaultAttributes_Point2D(), 2);
                    m_pGeometry->setLineWidth(1);
                    m_pGeometry->setDrawingMode(GL_LINES);
            
                    m_pGeometry->vertexDataAsPoint2D()[0].set(beginPoint.x(), beginPoint.y());
                    m_pGeometry->vertexDataAsPoint2D()[1].set(endPoint.x(), endPoint.y());
            
                    m_pGeometryNode->setGeometry(m_pGeometry);
                    m_pGeometryNode->setFlags(QSGNode::OwnsGeometry | QSGNode::OwnsMaterial);
                    m_pGeometryNode->setMaterial(m_pMaterial);
            
                    return m_pGeometryNode;
                }
                else
                {
                    oldNode->setMaterial(m_pMaterial);
                }
            
                return oldNode;
            }
            
            QSGGeometryNode *NavRect::existLineNode(QPoint beginPoint, QPoint endPoint, QColor colorLine, QSGGeometryNode *oldNode)
            {
                m_pMaterial->setColor(colorLine);
            
                oldNode->setMaterial(m_pMaterial);
            
                return oldNode;
            }
            
              BlinCT
              • April 3, 2020, 12:53 p.m.

              Само собою на компе этого незаметно.

                Evgenii Legotckoi
                • April 6, 2020, 4:19 a.m.

                Попробуй не переустанавливать материал, а просто менять цвет

                  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. 12, 2024, 9:12 a.m.
                  Django - Tutorial 055. How to write auto populate field functionality Freckles because of several brand names retin a, atralin buy generic priligy
                  i
                  innorwallNov. 12, 2024, 5:23 a.m.
                  QML - Tutorial 035. Using enumerations in QML without C ++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
                  i
                  innorwallNov. 12, 2024, 2:50 a.m.
                  Qt/C++ - Lesson 052. Customization Qt Audio player in the style of AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
                  i
                  innorwallNov. 12, 2024, 1:19 a.m.
                  Heap sorting algorithm The role of raloxifene in preventing breast cancer priligy precio
                  i
                  innorwallNov. 12, 2024, 12:55 a.m.
                  PyQt5 - Lesson 006. Work with QTableWidget buy priligy 60 mg 53 have been reported by Javanovic Santa et al
                  Now discuss on the forum
                  i
                  innorwallNov. 12, 2024, 7:56 a.m.
                  добавить qlineseries в функции buy priligy senior brother Chu He, whom he had known for many years
                  i
                  innorwallNov. 11, 2024, 9:55 p.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, 7:10 p.m.
                  Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                  Follow us in social networks