Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. Qt 6: Move QList contents without copying?
Forum Updated to NodeBB v4.3 + New Features

Qt 6: Move QList contents without copying?

Scheduled Pinned Locked Moved Unsolved General and Desktop
21 Posts 6 Posters 3.5k Views 3 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • CJhaC CJha

    @JonB QList does have an append overload for moving:

    void QList::append(QList<T> &&value)
    This is an overloaded function.
    Moves the items of the value list to the end of this list.
    This function was introduced in Qt 6.0.

    Technically, it should not copy but rather move and append the value from the passed list to fullList. Why is this not doing that?

    JonBJ Offline
    JonBJ Offline
    JonB
    wrote on last edited by
    #8

    @CJha
    I don't know since I have never used Qt 6.

    Depends what you/they mean by "move" versus "copy". I stick by my claim/understanding that since QList elements are now contiguous like an array/vector it must "copy" the elements to the destination list to make it so. The only difference is that it could invalidate the passed-in source list.

    I do not know how QList<T> might work with std::move(). I do not know whether it might leave list in an "unspecified state". Did you try, say, fullList.append(list); just to seen what happens to list after this case?

    This is the limit of my knowledge/guesswork! You probably need a QT + std expert to help you further :)

    jsulmJ CJhaC 2 Replies Last reply
    0
    • JonBJ JonB

      @CJha
      I don't know since I have never used Qt 6.

      Depends what you/they mean by "move" versus "copy". I stick by my claim/understanding that since QList elements are now contiguous like an array/vector it must "copy" the elements to the destination list to make it so. The only difference is that it could invalidate the passed-in source list.

      I do not know how QList<T> might work with std::move(). I do not know whether it might leave list in an "unspecified state". Did you try, say, fullList.append(list); just to seen what happens to list after this case?

      This is the limit of my knowledge/guesswork! You probably need a QT + std expert to help you further :)

      jsulmJ Offline
      jsulmJ Offline
      jsulm
      Lifetime Qt Champion
      wrote on last edited by
      #9

      @JonB No it does not have to copy if using std::move. As far as I know Qt container use heap allocated memory with a pointer for the actual data. Then using std::move it is enough to assign the pointer to the data in the destination container and set it to nullptr in the source container.

      https://forum.qt.io/topic/113070/qt-code-of-conduct

      JonBJ 1 Reply Last reply
      0
      • JonBJ JonB

        @CJha
        I don't know since I have never used Qt 6.

        Depends what you/they mean by "move" versus "copy". I stick by my claim/understanding that since QList elements are now contiguous like an array/vector it must "copy" the elements to the destination list to make it so. The only difference is that it could invalidate the passed-in source list.

        I do not know how QList<T> might work with std::move(). I do not know whether it might leave list in an "unspecified state". Did you try, say, fullList.append(list); just to seen what happens to list after this case?

        This is the limit of my knowledge/guesswork! You probably need a QT + std expert to help you further :)

        CJhaC Offline
        CJhaC Offline
        CJha
        wrote on last edited by
        #10

        @JonB Thanks. Yes, I did try multiple cases, here are few important ones

        fullList.append(list); // copies and appends the data from list to fullList but list itself is not changed
        
        fullList.append(std::move(list)); // same as above
        
        fullList = std::move(list); // moves the data from list to fullList, the list is empty but in defined state after this move
        

        It seems that it is only moving the data from list to fullList when the data is being assigned using = std::move() in all other cases it leaves the data in list as it was.

        1 Reply Last reply
        0
        • jsulmJ jsulm

          @JonB No it does not have to copy if using std::move. As far as I know Qt container use heap allocated memory with a pointer for the actual data. Then using std::move it is enough to assign the pointer to the data in the destination container and set it to nullptr in the source container.

          JonBJ Offline
          JonBJ Offline
          JonB
          wrote on last edited by
          #11

          @jsulm said in Qt 6: Move QList contents without copying?:

          @JonB No it does not have to copy if using std::move. As far as I know Qt container use heap allocated memory with a pointer for the actual data. Then using std::move it is enough to assign the pointer to the data in the destination container and set it to nullptr in the source container.

          Have you read what I wrote above about Qt6 and contiguous element allocation? What you write would indeed be the case for QList::QList(const QList<T> &other) constructor. However the user is asking about QList::append(QList<T> &&value) method introduced at Qt 6.0, that's the whole point. Could you explain how it could append a list to an existing list without having to copy the elements onto the existing list while still maintaining contiguous memory like an array/vector? I welcome your input :)

          jsulmJ Christian EhrlicherC 2 Replies Last reply
          0
          • JonBJ JonB

            @jsulm said in Qt 6: Move QList contents without copying?:

            @JonB No it does not have to copy if using std::move. As far as I know Qt container use heap allocated memory with a pointer for the actual data. Then using std::move it is enough to assign the pointer to the data in the destination container and set it to nullptr in the source container.

            Have you read what I wrote above about Qt6 and contiguous element allocation? What you write would indeed be the case for QList::QList(const QList<T> &other) constructor. However the user is asking about QList::append(QList<T> &&value) method introduced at Qt 6.0, that's the whole point. Could you explain how it could append a list to an existing list without having to copy the elements onto the existing list while still maintaining contiguous memory like an array/vector? I welcome your input :)

            jsulmJ Offline
            jsulmJ Offline
            jsulm
            Lifetime Qt Champion
            wrote on last edited by
            #12

            @JonB Sorry, you're of course right about append!

            https://forum.qt.io/topic/113070/qt-code-of-conduct

            1 Reply Last reply
            0
            • JonBJ JonB

              @jsulm said in Qt 6: Move QList contents without copying?:

              @JonB No it does not have to copy if using std::move. As far as I know Qt container use heap allocated memory with a pointer for the actual data. Then using std::move it is enough to assign the pointer to the data in the destination container and set it to nullptr in the source container.

              Have you read what I wrote above about Qt6 and contiguous element allocation? What you write would indeed be the case for QList::QList(const QList<T> &other) constructor. However the user is asking about QList::append(QList<T> &&value) method introduced at Qt 6.0, that's the whole point. Could you explain how it could append a list to an existing list without having to copy the elements onto the existing list while still maintaining contiguous memory like an array/vector? I welcome your input :)

              Christian EhrlicherC Offline
              Christian EhrlicherC Offline
              Christian Ehrlicher
              Lifetime Qt Champion
              wrote on last edited by Christian Ehrlicher
              #13

              @JonB said in Qt 6: Move QList contents without copying?:

              Could you explain how it could append a list to an existing list without having to copy the elements onto the existing list while still maintaining contiguous memory like an array/vector? I welcome your input :)

              It moves the data from memory a to memory b. It's just not a copy but a move operation. Nothing more.

              void addList(QList<T>& list) { fullList.append(std::move(list)); }

              How should this be moved at all when list is a const ref? You can move a const object...

              Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
              Visit the Qt Academy at https://academy.qt.io/catalog

              JonBJ 2 Replies Last reply
              0
              • Christian EhrlicherC Christian Ehrlicher

                @JonB said in Qt 6: Move QList contents without copying?:

                Could you explain how it could append a list to an existing list without having to copy the elements onto the existing list while still maintaining contiguous memory like an array/vector? I welcome your input :)

                It moves the data from memory a to memory b. It's just not a copy but a move operation. Nothing more.

                void addList(QList<T>& list) { fullList.append(std::move(list)); }

                How should this be moved at all when list is a const ref? You can move a const object...

                JonBJ Offline
                JonBJ Offline
                JonB
                wrote on last edited by JonB
                #14

                @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                It moves the data from memory a to memory b. It's just not a copy but a move operation. Nothing more.

                For this purpose I am calling that "copy" because (does it not?) have to copy the elements (in the QList, not what they might point to) from memory area a to area b? Certainly if iterates that is O(n), I don't know whether you mean CPUs have an instruction to do that fast instead? Think about if it appends a list of 1,000,000 items to an existing list of one item. Moving and appending a list (like a linked list) could be made an O(1) operation, but not with the vector implementation of Qt6 QList, that is my point. I think of "copy" for O(n), "move" to me implies O(1) (hopefully). Is this not correct?

                Christian EhrlicherC S 2 Replies Last reply
                0
                • JonBJ JonB

                  @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                  It moves the data from memory a to memory b. It's just not a copy but a move operation. Nothing more.

                  For this purpose I am calling that "copy" because (does it not?) have to copy the elements (in the QList, not what they might point to) from memory area a to area b? Certainly if iterates that is O(n), I don't know whether you mean CPUs have an instruction to do that fast instead? Think about if it appends a list of 1,000,000 items to an existing list of one item. Moving and appending a list (like a linked list) could be made an O(1) operation, but not with the vector implementation of Qt6 QList, that is my point. I think of "copy" for O(n), "move" to me implies O(1) (hopefully). Is this not correct?

                  Christian EhrlicherC Offline
                  Christian EhrlicherC Offline
                  Christian Ehrlicher
                  Lifetime Qt Champion
                  wrote on last edited by
                  #15

                  @JonB Don't look on the QList but it's contents. The content is moved but not copied - so the move ctor is called and not the copy ctor.

                  Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                  Visit the Qt Academy at https://academy.qt.io/catalog

                  JonBJ 1 Reply Last reply
                  0
                  • Christian EhrlicherC Christian Ehrlicher

                    @JonB Don't look on the QList but it's contents. The content is moved but not copied - so the move ctor is called and not the copy ctor.

                    JonBJ Offline
                    JonBJ Offline
                    JonB
                    wrote on last edited by JonB
                    #16

                    @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                    so the move ctor is called and not the copy ctor.

                    I never suggested otherwise. My question/answer at least is based on my assumption that the implementation in move constructor will be O(n) and not O(1) at Qt6 QList which requires contiguous memory. Which is what I would care about (at least as part of the whole) if I were asking the OP's question.

                    Christian EhrlicherC 1 Reply Last reply
                    1
                    • JonBJ JonB

                      @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                      so the move ctor is called and not the copy ctor.

                      I never suggested otherwise. My question/answer at least is based on my assumption that the implementation in move constructor will be O(n) and not O(1) at Qt6 QList which requires contiguous memory. Which is what I would care about (at least as part of the whole) if I were asking the OP's question.

                      Christian EhrlicherC Offline
                      Christian EhrlicherC Offline
                      Christian Ehrlicher
                      Lifetime Qt Champion
                      wrote on last edited by Christian Ehrlicher
                      #17

                      @JonB said in Qt 6: Move QList contents without copying?:

                      Which is what I would care about (at least as part of the whole) if I were asking the OP's question.

                      But even then a move would be faster than (or equal if QList contains a pod) a copy. But the complexity stays, yes. But as I said - it can't work the way it is written.

                      Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                      Visit the Qt Academy at https://academy.qt.io/catalog

                      1 Reply Last reply
                      0
                      • Christian EhrlicherC Christian Ehrlicher

                        @JonB said in Qt 6: Move QList contents without copying?:

                        Could you explain how it could append a list to an existing list without having to copy the elements onto the existing list while still maintaining contiguous memory like an array/vector? I welcome your input :)

                        It moves the data from memory a to memory b. It's just not a copy but a move operation. Nothing more.

                        void addList(QList<T>& list) { fullList.append(std::move(list)); }

                        How should this be moved at all when list is a const ref? You can move a const object...

                        JonBJ Offline
                        JonBJ Offline
                        JonB
                        wrote on last edited by JonB
                        #18

                        @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                        But the complexity stays, yes.

                        OK.

                        @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                        How should this be moved at all when list is a const ref? You can move a const object...

                        @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                        But as I said - it can't work the way it is written.

                        Sorry, don't know about others but I'm not understanding where " list is a const ref" here, where is the const? Please be gentle in your answer ;-)
                        [Also, did you mean "You can move a const object..." or did you mean "can't"?]

                        Christian EhrlicherC 1 Reply Last reply
                        0
                        • JonBJ JonB

                          @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                          But the complexity stays, yes.

                          OK.

                          @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                          How should this be moved at all when list is a const ref? You can move a const object...

                          @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                          But as I said - it can't work the way it is written.

                          Sorry, don't know about others but I'm not understanding where " list is a const ref" here, where is the const? Please be gentle in your answer ;-)
                          [Also, did you mean "You can move a const object..." or did you mean "can't"?]

                          Christian EhrlicherC Offline
                          Christian EhrlicherC Offline
                          Christian Ehrlicher
                          Lifetime Qt Champion
                          wrote on last edited by Christian Ehrlicher
                          #19

                          @JonB said in Qt 6: Move QList contents without copying?:

                          list is a const ref" here, where is the const? Please be gentle in your answer ;-)

                          void addList(QList<T>& list) { fullList.append(std::move(list)); }

                          list is const - so nothing to move here.

                          Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                          Visit the Qt Academy at https://academy.qt.io/catalog

                          Christian EhrlicherC 1 Reply Last reply
                          0
                          • Christian EhrlicherC Christian Ehrlicher

                            @JonB said in Qt 6: Move QList contents without copying?:

                            list is a const ref" here, where is the const? Please be gentle in your answer ;-)

                            void addList(QList<T>& list) { fullList.append(std::move(list)); }

                            list is const - so nothing to move here.

                            Christian EhrlicherC Offline
                            Christian EhrlicherC Offline
                            Christian Ehrlicher
                            Lifetime Qt Champion
                            wrote on last edited by
                            #20

                            Here I somehow was in the wrong path... sorry for the noise:

                            class CopyMoveTest
                            {
                            public:
                              CopyMoveTest() { std::cout << "CopyMoveTest: plain ctor\n"; }
                              CopyMoveTest(const CopyMoveTest &) { std::cout << "CopyMoveTest: copy ctor\n"; }
                              CopyMoveTest(CopyMoveTest &&) { std::cout << "CopyMoveTest: move ctor\n"; }
                            
                              CopyMoveTest operator=(const CopyMoveTest &) { std::cout << "CopyMoveTest: copy operator\n"; return *this; }
                              CopyMoveTest operator=(const CopyMoveTest &&) { std::cout << "CopyMoveTest: move operator\n"; return *this; }
                            };
                            
                            void refCopy(CopyMoveTest &in)
                            {
                              CopyMoveTest c(in);
                            }
                            
                            void rValueRefCopy(CopyMoveTest &&in)
                            {
                              CopyMoveTest c(in);
                            }
                            
                            void refMove(CopyMoveTest &in)
                            {
                              CopyMoveTest c(std::move(in));
                            }
                            
                            void rValueRefMove(CopyMoveTest &&in)
                            {
                              CopyMoveTest c(std::move(in));
                            }
                            
                            int main(int , char **)
                            {
                              CopyMoveTest a;
                              std::cout << "\nref source copy\n";
                              refCopy(a);
                              std::cout << "\nref source move\n";
                              refMove(a);
                              std::cout << "\nrvalue ref source copy\n";
                              rValueRefCopy(std::move(a));
                              std::cout << "\nrvalue ref source move\n";
                              rValueRefMove(std::move(a));
                            }
                            
                            -->
                            CopyMoveTest: plain ctor
                            
                            ref source copy
                            CopyMoveTest: copy ctor
                            
                            ref source move
                            CopyMoveTest: move ctor
                            
                            rvalue ref source copy
                            CopyMoveTest: copy ctor
                            
                            rvalue ref source move
                            CopyMoveTest: move ctor
                            
                            

                            Qt Online Installer direct download: https://download.qt.io/official_releases/online_installers/
                            Visit the Qt Academy at https://academy.qt.io/catalog

                            1 Reply Last reply
                            1
                            • JonBJ JonB

                              @Christian-Ehrlicher said in Qt 6: Move QList contents without copying?:

                              It moves the data from memory a to memory b. It's just not a copy but a move operation. Nothing more.

                              For this purpose I am calling that "copy" because (does it not?) have to copy the elements (in the QList, not what they might point to) from memory area a to area b? Certainly if iterates that is O(n), I don't know whether you mean CPUs have an instruction to do that fast instead? Think about if it appends a list of 1,000,000 items to an existing list of one item. Moving and appending a list (like a linked list) could be made an O(1) operation, but not with the vector implementation of Qt6 QList, that is my point. I think of "copy" for O(n), "move" to me implies O(1) (hopefully). Is this not correct?

                              S Offline
                              S Offline
                              SimonSchroeder
                              wrote on last edited by
                              #21

                              @JonB said in Qt 6: Move QList contents without copying?:

                              Think about if it appends a list of 1,000,000 items to an existing list of one item. Moving and appending a list (like a linked list) could be made an O(1) operation

                              Well, you are right about that. However, I would expect that something would be done with the data afterwards. Iterating over the elements of a linked list and the elements of a vector is both O(n). Still, in the general case a vector will be faster because of consecutive memory whereas a list might have many cache misses. If iteration is done more than once the vector might be faster (after copying 1,000,000 items). It is a very tricky problem.

                              1 Reply Last reply
                              0

                              • Login

                              • Login or register to search.
                              • First post
                                Last post
                              0
                              • Categories
                              • Recent
                              • Tags
                              • Popular
                              • Users
                              • Groups
                              • Search
                              • Get Qt Extensions
                              • Unsolved