What is the result of assigning to std::vector::begin()? The Next CEO of Stack OverflowWhat are the differences between a pointer variable and a reference variable in C++?What does the explicit keyword mean?Concatenating two std::vectorsHow to find out if an item is present in a std::vector?Why is “using namespace std” considered bad practice?What is the “-->” operator in C++?What is the easiest way to initialize a std::vector with hardcoded elements?What is The Rule of Three?What are the basic rules and idioms for operator overloading?Why are std::begin and std::end “not memory safe”?

How fast would a person need to move to trick the eye?

Written every which way

Would this house-rule that treats advantage as a +1 to the roll instead (and disadvantage as -1) and allows them to stack be balanced?

How do I go from 300 unfinished/half written blog posts, to published posts?

If a black hole is created from light, can this black hole then move at speed of light?

What happens if you roll doubles 3 times then land on "Go to jail?"

What can we do to stop prior company from asking us questions?

Why am I allowed to create multiple unique pointers from a single object?

In excess I'm lethal

Is it my responsibility to learn a new technology in my own time my employer wants to implement?

Bold, vivid family

Example of a Mathematician/Physicist whose Other Publications during their PhD eclipsed their PhD Thesis

FBX seems to be empty when imported into Blender

Should I tutor a student who I know has cheated on their homework?

How do we know the LHC results are robust?

Is micro rebar a better way to reinforce concrete than rebar?

Is HostGator storing my password in plaintext?

Non-deterministic sum of floats

Does it take more energy to get to Venus or to Mars?

Contours of a clandestine nature

How to start emacs in "nothing" mode (`fundamental-mode`)

What flight has the highest ratio of time difference to flight time?

MessageLevel in QGIS3

How to transpose the 1st and -1th levels of arbitrarily nested array?



What is the result of assigning to std::vector::begin()?



The Next CEO of Stack OverflowWhat are the differences between a pointer variable and a reference variable in C++?What does the explicit keyword mean?Concatenating two std::vectorsHow to find out if an item is present in a std::vector?Why is “using namespace std” considered bad practice?What is the “-->” operator in C++?What is the easiest way to initialize a std::vector with hardcoded elements?What is The Rule of Three?What are the basic rules and idioms for operator overloading?Why are std::begin and std::end “not memory safe”?










6















I've a bit understanding about lvalue and rvalues. So as I know we cannot assign to an rvalue but non-const lvalue is ok.



#include <iostream>
#include <vector>
int main()

std::vector<int> v 1, 2, 3, 4, 5 ;
v.begin() = v.end() - 2;
std::cout << *v.begin() << std::endl; // 1
for (auto const& e : v)
std::cout << e << ", ";// 1, 2, 3, 4, 5,
std::cout << std::endl;



Why I can assign to begin() but it does nothing on the elements?










share|improve this question









New contributor




Syfu_H is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.




















  • Why would you expect it to change anything in the vector? All you modify is an iterator

    – UnholySheep
    1 hour ago






  • 2





    It compiles if you include the necessary header files - I've added them. Why people think that including these in their question is optional, I will never know.

    – Neil Butterworth
    1 hour ago












  • @RSahu: Here is the output from Ideone: ideone.com/19AVFF

    – Syfu_H
    1 hour ago















6















I've a bit understanding about lvalue and rvalues. So as I know we cannot assign to an rvalue but non-const lvalue is ok.



#include <iostream>
#include <vector>
int main()

std::vector<int> v 1, 2, 3, 4, 5 ;
v.begin() = v.end() - 2;
std::cout << *v.begin() << std::endl; // 1
for (auto const& e : v)
std::cout << e << ", ";// 1, 2, 3, 4, 5,
std::cout << std::endl;



Why I can assign to begin() but it does nothing on the elements?










share|improve this question









New contributor




Syfu_H is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.




















  • Why would you expect it to change anything in the vector? All you modify is an iterator

    – UnholySheep
    1 hour ago






  • 2





    It compiles if you include the necessary header files - I've added them. Why people think that including these in their question is optional, I will never know.

    – Neil Butterworth
    1 hour ago












  • @RSahu: Here is the output from Ideone: ideone.com/19AVFF

    – Syfu_H
    1 hour ago













6












6








6


5






I've a bit understanding about lvalue and rvalues. So as I know we cannot assign to an rvalue but non-const lvalue is ok.



#include <iostream>
#include <vector>
int main()

std::vector<int> v 1, 2, 3, 4, 5 ;
v.begin() = v.end() - 2;
std::cout << *v.begin() << std::endl; // 1
for (auto const& e : v)
std::cout << e << ", ";// 1, 2, 3, 4, 5,
std::cout << std::endl;



Why I can assign to begin() but it does nothing on the elements?










share|improve this question









New contributor




Syfu_H is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.












I've a bit understanding about lvalue and rvalues. So as I know we cannot assign to an rvalue but non-const lvalue is ok.



#include <iostream>
#include <vector>
int main()

std::vector<int> v 1, 2, 3, 4, 5 ;
v.begin() = v.end() - 2;
std::cout << *v.begin() << std::endl; // 1
for (auto const& e : v)
std::cout << e << ", ";// 1, 2, 3, 4, 5,
std::cout << std::endl;



Why I can assign to begin() but it does nothing on the elements?







c++ vector






share|improve this question









New contributor




Syfu_H is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.











share|improve this question









New contributor




Syfu_H is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









share|improve this question




share|improve this question








edited 1 hour ago









Neil Butterworth

27.2k54681




27.2k54681






New contributor




Syfu_H is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.









asked 1 hour ago









Syfu_HSyfu_H

463




463




New contributor




Syfu_H is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.





New contributor





Syfu_H is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.






Syfu_H is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.












  • Why would you expect it to change anything in the vector? All you modify is an iterator

    – UnholySheep
    1 hour ago






  • 2





    It compiles if you include the necessary header files - I've added them. Why people think that including these in their question is optional, I will never know.

    – Neil Butterworth
    1 hour ago












  • @RSahu: Here is the output from Ideone: ideone.com/19AVFF

    – Syfu_H
    1 hour ago

















  • Why would you expect it to change anything in the vector? All you modify is an iterator

    – UnholySheep
    1 hour ago






  • 2





    It compiles if you include the necessary header files - I've added them. Why people think that including these in their question is optional, I will never know.

    – Neil Butterworth
    1 hour ago












  • @RSahu: Here is the output from Ideone: ideone.com/19AVFF

    – Syfu_H
    1 hour ago
















Why would you expect it to change anything in the vector? All you modify is an iterator

– UnholySheep
1 hour ago





Why would you expect it to change anything in the vector? All you modify is an iterator

– UnholySheep
1 hour ago




2




2





It compiles if you include the necessary header files - I've added them. Why people think that including these in their question is optional, I will never know.

– Neil Butterworth
1 hour ago






It compiles if you include the necessary header files - I've added them. Why people think that including these in their question is optional, I will never know.

– Neil Butterworth
1 hour ago














@RSahu: Here is the output from Ideone: ideone.com/19AVFF

– Syfu_H
1 hour ago





@RSahu: Here is the output from Ideone: ideone.com/19AVFF

– Syfu_H
1 hour ago












3 Answers
3






active

oldest

votes


















10














v.begin() is an iterator. Assigning to an iterator does not assign to the value the iterator points to. In addition, because v.begin() is a prvalue, the object that you are assigning to gets destroyed at the end of the line, without affecting v or any of the "permanent" memory it owns.



If v.begin() were a raw pointer, the compiler would issue an error for trying to assign to an rvalue. However, the type std::vector<T>::iterator is often a class type, and it seems that this is the case on your implementation (with the specific set of compiler flags you are using), so assigning to v.begin() calls the operator= of that class type. But that doesn't change the fact that the iterator object is a temporary object, and assigning to it has no further effects.



In order to assign to the element that v.begin() points to, you need to dereference it: *v.begin() = *(v.end() - 2)






share|improve this answer























  • What, no digression into lvalue qualified member functions?

    – Yakk - Adam Nevraumont
    1 hour ago


















5















What is the result of assigning to std::vector::begin()?




The result of the assignment expression (the result is discarded in your example) is the assigned value. In this case the result is same as v.end() - 2.



Note that since begin() returns a value, this assignment only modifies the returned temporary object. The assignment doesn't modify the vector in any way. Given that the temporary object is discarded, the assignment has no observable effects in practice.



Futhermore, this assignment may be ill-formed if the standard library has chosen to implement std::vector::iterator as a pointer.




Why I cdagger typoan assign to begin()




Because



  1. Iterators are assignable.

  2. Rvalues of class type can be assigned .

  3. The iterator happens to be a class type.


but it does nothing on the elements?




Because assigning an iterator doesn't modify the element that the iterator points at. Instead, the assignment changes what object the iterator is pointing at.




So as I know we cannot assign to an rvalue




This is not correct in general. In particular, it is not true for class types .




Unless the assignment operator of the class has ref-qualifier (and has no rvalue-ref-qualified overload), which is unconventional.






share|improve this answer

























  • How is a ref qualifier on an assignment operator "unconventional"? I'm unaware of any decent coding convention that fails to recommend it.

    – Yakk - Adam Nevraumont
    1 hour ago











  • @Yakk-AdamNevraumont It's not conventional for the standard library as far as I know. Can you name a class from standard library that uses it? I don't recall any, but that doesn't of course mean that they don't exist.

    – eerorika
    1 hour ago












  • @eerorika While looking into another question, I've just found std::optional::value that has ref qualifiers. I don't remember seeing them anywhere else in the standard library though.

    – François Andrieux
    51 mins ago



















0














Sometimes code explains things better than words. Your code is equivalent to this:



std::vector<int> v 1, 2, 3, 4, 5 ;


auto temp = v.begin();
temp = v.end() - 2;


std::cout << *v.begin() << std::endl; // 1
for (auto const& e : v)
std::cout << e << ", ";// 1, 2, 3, 4, 5,
std::cout << std::endl;


In other words, v.begin() = v.end() - 2 has no observable effect. It's just an assignment to a temporary.






share|improve this answer























    Your Answer






    StackExchange.ifUsing("editor", function ()
    StackExchange.using("externalEditor", function ()
    StackExchange.using("snippets", function ()
    StackExchange.snippets.init();
    );
    );
    , "code-snippets");

    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "1"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );






    Syfu_H is a new contributor. Be nice, and check out our Code of Conduct.









    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55424362%2fwhat-is-the-result-of-assigning-to-stdvectortbegin%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    3 Answers
    3






    active

    oldest

    votes








    3 Answers
    3






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    10














    v.begin() is an iterator. Assigning to an iterator does not assign to the value the iterator points to. In addition, because v.begin() is a prvalue, the object that you are assigning to gets destroyed at the end of the line, without affecting v or any of the "permanent" memory it owns.



    If v.begin() were a raw pointer, the compiler would issue an error for trying to assign to an rvalue. However, the type std::vector<T>::iterator is often a class type, and it seems that this is the case on your implementation (with the specific set of compiler flags you are using), so assigning to v.begin() calls the operator= of that class type. But that doesn't change the fact that the iterator object is a temporary object, and assigning to it has no further effects.



    In order to assign to the element that v.begin() points to, you need to dereference it: *v.begin() = *(v.end() - 2)






    share|improve this answer























    • What, no digression into lvalue qualified member functions?

      – Yakk - Adam Nevraumont
      1 hour ago















    10














    v.begin() is an iterator. Assigning to an iterator does not assign to the value the iterator points to. In addition, because v.begin() is a prvalue, the object that you are assigning to gets destroyed at the end of the line, without affecting v or any of the "permanent" memory it owns.



    If v.begin() were a raw pointer, the compiler would issue an error for trying to assign to an rvalue. However, the type std::vector<T>::iterator is often a class type, and it seems that this is the case on your implementation (with the specific set of compiler flags you are using), so assigning to v.begin() calls the operator= of that class type. But that doesn't change the fact that the iterator object is a temporary object, and assigning to it has no further effects.



    In order to assign to the element that v.begin() points to, you need to dereference it: *v.begin() = *(v.end() - 2)






    share|improve this answer























    • What, no digression into lvalue qualified member functions?

      – Yakk - Adam Nevraumont
      1 hour ago













    10












    10








    10







    v.begin() is an iterator. Assigning to an iterator does not assign to the value the iterator points to. In addition, because v.begin() is a prvalue, the object that you are assigning to gets destroyed at the end of the line, without affecting v or any of the "permanent" memory it owns.



    If v.begin() were a raw pointer, the compiler would issue an error for trying to assign to an rvalue. However, the type std::vector<T>::iterator is often a class type, and it seems that this is the case on your implementation (with the specific set of compiler flags you are using), so assigning to v.begin() calls the operator= of that class type. But that doesn't change the fact that the iterator object is a temporary object, and assigning to it has no further effects.



    In order to assign to the element that v.begin() points to, you need to dereference it: *v.begin() = *(v.end() - 2)






    share|improve this answer













    v.begin() is an iterator. Assigning to an iterator does not assign to the value the iterator points to. In addition, because v.begin() is a prvalue, the object that you are assigning to gets destroyed at the end of the line, without affecting v or any of the "permanent" memory it owns.



    If v.begin() were a raw pointer, the compiler would issue an error for trying to assign to an rvalue. However, the type std::vector<T>::iterator is often a class type, and it seems that this is the case on your implementation (with the specific set of compiler flags you are using), so assigning to v.begin() calls the operator= of that class type. But that doesn't change the fact that the iterator object is a temporary object, and assigning to it has no further effects.



    In order to assign to the element that v.begin() points to, you need to dereference it: *v.begin() = *(v.end() - 2)







    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered 1 hour ago









    BrianBrian

    66.2k798189




    66.2k798189












    • What, no digression into lvalue qualified member functions?

      – Yakk - Adam Nevraumont
      1 hour ago

















    • What, no digression into lvalue qualified member functions?

      – Yakk - Adam Nevraumont
      1 hour ago
















    What, no digression into lvalue qualified member functions?

    – Yakk - Adam Nevraumont
    1 hour ago





    What, no digression into lvalue qualified member functions?

    – Yakk - Adam Nevraumont
    1 hour ago













    5















    What is the result of assigning to std::vector::begin()?




    The result of the assignment expression (the result is discarded in your example) is the assigned value. In this case the result is same as v.end() - 2.



    Note that since begin() returns a value, this assignment only modifies the returned temporary object. The assignment doesn't modify the vector in any way. Given that the temporary object is discarded, the assignment has no observable effects in practice.



    Futhermore, this assignment may be ill-formed if the standard library has chosen to implement std::vector::iterator as a pointer.




    Why I cdagger typoan assign to begin()




    Because



    1. Iterators are assignable.

    2. Rvalues of class type can be assigned .

    3. The iterator happens to be a class type.


    but it does nothing on the elements?




    Because assigning an iterator doesn't modify the element that the iterator points at. Instead, the assignment changes what object the iterator is pointing at.




    So as I know we cannot assign to an rvalue




    This is not correct in general. In particular, it is not true for class types .




    Unless the assignment operator of the class has ref-qualifier (and has no rvalue-ref-qualified overload), which is unconventional.






    share|improve this answer

























    • How is a ref qualifier on an assignment operator "unconventional"? I'm unaware of any decent coding convention that fails to recommend it.

      – Yakk - Adam Nevraumont
      1 hour ago











    • @Yakk-AdamNevraumont It's not conventional for the standard library as far as I know. Can you name a class from standard library that uses it? I don't recall any, but that doesn't of course mean that they don't exist.

      – eerorika
      1 hour ago












    • @eerorika While looking into another question, I've just found std::optional::value that has ref qualifiers. I don't remember seeing them anywhere else in the standard library though.

      – François Andrieux
      51 mins ago
















    5















    What is the result of assigning to std::vector::begin()?




    The result of the assignment expression (the result is discarded in your example) is the assigned value. In this case the result is same as v.end() - 2.



    Note that since begin() returns a value, this assignment only modifies the returned temporary object. The assignment doesn't modify the vector in any way. Given that the temporary object is discarded, the assignment has no observable effects in practice.



    Futhermore, this assignment may be ill-formed if the standard library has chosen to implement std::vector::iterator as a pointer.




    Why I cdagger typoan assign to begin()




    Because



    1. Iterators are assignable.

    2. Rvalues of class type can be assigned .

    3. The iterator happens to be a class type.


    but it does nothing on the elements?




    Because assigning an iterator doesn't modify the element that the iterator points at. Instead, the assignment changes what object the iterator is pointing at.




    So as I know we cannot assign to an rvalue




    This is not correct in general. In particular, it is not true for class types .




    Unless the assignment operator of the class has ref-qualifier (and has no rvalue-ref-qualified overload), which is unconventional.






    share|improve this answer

























    • How is a ref qualifier on an assignment operator "unconventional"? I'm unaware of any decent coding convention that fails to recommend it.

      – Yakk - Adam Nevraumont
      1 hour ago











    • @Yakk-AdamNevraumont It's not conventional for the standard library as far as I know. Can you name a class from standard library that uses it? I don't recall any, but that doesn't of course mean that they don't exist.

      – eerorika
      1 hour ago












    • @eerorika While looking into another question, I've just found std::optional::value that has ref qualifiers. I don't remember seeing them anywhere else in the standard library though.

      – François Andrieux
      51 mins ago














    5












    5








    5








    What is the result of assigning to std::vector::begin()?




    The result of the assignment expression (the result is discarded in your example) is the assigned value. In this case the result is same as v.end() - 2.



    Note that since begin() returns a value, this assignment only modifies the returned temporary object. The assignment doesn't modify the vector in any way. Given that the temporary object is discarded, the assignment has no observable effects in practice.



    Futhermore, this assignment may be ill-formed if the standard library has chosen to implement std::vector::iterator as a pointer.




    Why I cdagger typoan assign to begin()




    Because



    1. Iterators are assignable.

    2. Rvalues of class type can be assigned .

    3. The iterator happens to be a class type.


    but it does nothing on the elements?




    Because assigning an iterator doesn't modify the element that the iterator points at. Instead, the assignment changes what object the iterator is pointing at.




    So as I know we cannot assign to an rvalue




    This is not correct in general. In particular, it is not true for class types .




    Unless the assignment operator of the class has ref-qualifier (and has no rvalue-ref-qualified overload), which is unconventional.






    share|improve this answer
















    What is the result of assigning to std::vector::begin()?




    The result of the assignment expression (the result is discarded in your example) is the assigned value. In this case the result is same as v.end() - 2.



    Note that since begin() returns a value, this assignment only modifies the returned temporary object. The assignment doesn't modify the vector in any way. Given that the temporary object is discarded, the assignment has no observable effects in practice.



    Futhermore, this assignment may be ill-formed if the standard library has chosen to implement std::vector::iterator as a pointer.




    Why I cdagger typoan assign to begin()




    Because



    1. Iterators are assignable.

    2. Rvalues of class type can be assigned .

    3. The iterator happens to be a class type.


    but it does nothing on the elements?




    Because assigning an iterator doesn't modify the element that the iterator points at. Instead, the assignment changes what object the iterator is pointing at.




    So as I know we cannot assign to an rvalue




    This is not correct in general. In particular, it is not true for class types .




    Unless the assignment operator of the class has ref-qualifier (and has no rvalue-ref-qualified overload), which is unconventional.







    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited 43 mins ago

























    answered 1 hour ago









    eerorikaeerorika

    88.2k663134




    88.2k663134












    • How is a ref qualifier on an assignment operator "unconventional"? I'm unaware of any decent coding convention that fails to recommend it.

      – Yakk - Adam Nevraumont
      1 hour ago











    • @Yakk-AdamNevraumont It's not conventional for the standard library as far as I know. Can you name a class from standard library that uses it? I don't recall any, but that doesn't of course mean that they don't exist.

      – eerorika
      1 hour ago












    • @eerorika While looking into another question, I've just found std::optional::value that has ref qualifiers. I don't remember seeing them anywhere else in the standard library though.

      – François Andrieux
      51 mins ago


















    • How is a ref qualifier on an assignment operator "unconventional"? I'm unaware of any decent coding convention that fails to recommend it.

      – Yakk - Adam Nevraumont
      1 hour ago











    • @Yakk-AdamNevraumont It's not conventional for the standard library as far as I know. Can you name a class from standard library that uses it? I don't recall any, but that doesn't of course mean that they don't exist.

      – eerorika
      1 hour ago












    • @eerorika While looking into another question, I've just found std::optional::value that has ref qualifiers. I don't remember seeing them anywhere else in the standard library though.

      – François Andrieux
      51 mins ago

















    How is a ref qualifier on an assignment operator "unconventional"? I'm unaware of any decent coding convention that fails to recommend it.

    – Yakk - Adam Nevraumont
    1 hour ago





    How is a ref qualifier on an assignment operator "unconventional"? I'm unaware of any decent coding convention that fails to recommend it.

    – Yakk - Adam Nevraumont
    1 hour ago













    @Yakk-AdamNevraumont It's not conventional for the standard library as far as I know. Can you name a class from standard library that uses it? I don't recall any, but that doesn't of course mean that they don't exist.

    – eerorika
    1 hour ago






    @Yakk-AdamNevraumont It's not conventional for the standard library as far as I know. Can you name a class from standard library that uses it? I don't recall any, but that doesn't of course mean that they don't exist.

    – eerorika
    1 hour ago














    @eerorika While looking into another question, I've just found std::optional::value that has ref qualifiers. I don't remember seeing them anywhere else in the standard library though.

    – François Andrieux
    51 mins ago






    @eerorika While looking into another question, I've just found std::optional::value that has ref qualifiers. I don't remember seeing them anywhere else in the standard library though.

    – François Andrieux
    51 mins ago












    0














    Sometimes code explains things better than words. Your code is equivalent to this:



    std::vector<int> v 1, 2, 3, 4, 5 ;


    auto temp = v.begin();
    temp = v.end() - 2;


    std::cout << *v.begin() << std::endl; // 1
    for (auto const& e : v)
    std::cout << e << ", ";// 1, 2, 3, 4, 5,
    std::cout << std::endl;


    In other words, v.begin() = v.end() - 2 has no observable effect. It's just an assignment to a temporary.






    share|improve this answer



























      0














      Sometimes code explains things better than words. Your code is equivalent to this:



      std::vector<int> v 1, 2, 3, 4, 5 ;


      auto temp = v.begin();
      temp = v.end() - 2;


      std::cout << *v.begin() << std::endl; // 1
      for (auto const& e : v)
      std::cout << e << ", ";// 1, 2, 3, 4, 5,
      std::cout << std::endl;


      In other words, v.begin() = v.end() - 2 has no observable effect. It's just an assignment to a temporary.






      share|improve this answer

























        0












        0








        0







        Sometimes code explains things better than words. Your code is equivalent to this:



        std::vector<int> v 1, 2, 3, 4, 5 ;


        auto temp = v.begin();
        temp = v.end() - 2;


        std::cout << *v.begin() << std::endl; // 1
        for (auto const& e : v)
        std::cout << e << ", ";// 1, 2, 3, 4, 5,
        std::cout << std::endl;


        In other words, v.begin() = v.end() - 2 has no observable effect. It's just an assignment to a temporary.






        share|improve this answer













        Sometimes code explains things better than words. Your code is equivalent to this:



        std::vector<int> v 1, 2, 3, 4, 5 ;


        auto temp = v.begin();
        temp = v.end() - 2;


        std::cout << *v.begin() << std::endl; // 1
        for (auto const& e : v)
        std::cout << e << ", ";// 1, 2, 3, 4, 5,
        std::cout << std::endl;


        In other words, v.begin() = v.end() - 2 has no observable effect. It's just an assignment to a temporary.







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 52 mins ago









        Nikos C.Nikos C.

        33.8k53967




        33.8k53967




















            Syfu_H is a new contributor. Be nice, and check out our Code of Conduct.









            draft saved

            draft discarded


















            Syfu_H is a new contributor. Be nice, and check out our Code of Conduct.












            Syfu_H is a new contributor. Be nice, and check out our Code of Conduct.











            Syfu_H is a new contributor. Be nice, and check out our Code of Conduct.














            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55424362%2fwhat-is-the-result-of-assigning-to-stdvectortbegin%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Станькаў Зьмест Назва | Гісторыя | Насельніцтва | Турыстычная інфармацыя | Галерэя | Асобы | Заўвагі | Крыніцы | Літаратура | Вонкавыя спасылкі | Навігацыйнае мэню53°37′48″ пн. ш. 27°13′40″ у. д. / 53.63° пн. ш. 27.22778° у. д. / 53.63; 27.2277853°37′48″ пн. ш. 27°13′40″ у. д. / 53.63° пн. ш. 27.22778° у. д. / 53.63; 27.22778djvu"Бабёнка – это я понимаю!". Як русіфікавалі тапонімы.Святыя руіны ажываюць210Станькаўв. СтанькаваСтаньково: история и новости - сайт деревниСтанькава: сядзіба Гутэн-Чапскіхррр

            J. J. Abrams Índice Traxectoria | Filmografía | Premios | Notas | Véxase tamén | Menú de navegacióne"J.J. Abrams: Biography"Arquivado"'Star Trek' sequel on track"Arquivado"J.J. Abrams Producing Samurai Jack Movie"Arquivado"EXCLUSIVE: J.J. Abrams Goes Into Warp Speed with Star Trek and Beyond"Arquivado"David Semel To Direct Jonah Nolan/J.J. Abrams' CBS Pilot 'Person Of Interest'"Arquivado"Fox orders J.J. Abrams pilot 'Alcatraz'"ArquivadoJ. J. AbramsJ. J. AbramsWorldCat81800131p24091041000XX116709414031616ma11226833654496ID052246713376222X511412nm00091900000 0001 1772 5428no98124254ID0000002883100650044xx0054597000141374297344064w64f2mjx14255303415344

            Першая сусьветная вайна Зьмест Чыньнікі | Асноўныя падзеі | Беларусь у гады вайны | Балянс вайны | Глядзіце таксама | Крыніцы | Вонкавыя спасылкі | Навігацыйнае мэнюПершая сусьветная вайна: памяць павінна жыць124 (27489)41990-763xЗападный мир отмечает 90 лет со дня окончания Первой мировой войныПершая сусьветная вайнаСпадчына Першай сусьветнай вайныГісторыя вайныАрхіў дакумэнтаў вайныМапы Эўропы ў ходзе вайныГісторыя пад знакам Пагоні/Першая сусветная вайна і Беларусь