0
How to move string | const ref
Hi Refer code below: I am concerned about set method. As it needs a copy constructor of std::string , I want to avoid that expensive operation . One thought came to my mind is use rvalue as below: void set(string&& s) {m_str = move(s);} This avoid copy constructor , but it will not work for second case in main function (that is l value). So, I thought as below: void set(const string& s) {m_str = move(s);} This works for both cases of lvalue and rvalue. Is this valid code ? Confusion is about move and const both. move modify the s and set it to empty but still we are string that const string& s providing confirmation that s is not updated by function. https://sololearn.com/compiler-playground/cosEyAgQqz5P/?ref=app
6 Respostas
+ 2
const ref&& is for rvalue and will not work here or is a bad idea to do.
It is better you use the old implementation for this problem. You will set pointer instead
mystr a;
set(&a);
0
there's a trick in the second version of <my_string::set> you need to be aware of it, namely that " m_str = std::move(s); " doesn't actually move anything. It merely tells the compiler to try to move.
however, since <std::string> class has no "assignment operator" that accepts a "const std::string&&", it will instead use the "const std::string&" copy assignment operator, and safely copy assign. no danger, no trap.
see yourself:
https://sololearn.com/compiler-playground/cD5MZA3uiu1G/?ref=app
0
Thanks MO ELomari, but I could not digest this information.
Let me go one by one to have my understanding better.
1. Is it not guaranteed that object is moved always when we have used std::move?
2. What are these const rvalue ref functions? I thought we don't have any function which has const T&& as const and r value ref cannot be together.
0
1:
<std::move> call doesn’t move anything. It is just a request. more precisely, it is a cast request to cast its argument to an rvalue ( is just a cast operation, nothing more, nothing less ):
https://en.cppreference.com/w/cpp/utility/move#Return_value
It works perfectly as we expect if its argument is an rvalue reference and corresponding move constructor expects exactly the same argument type including constness ( Regardless of whether its argument is lvalue reference or rvalue reference, <std::move> simply casts to rvalue reference. that’s it ).
2:
in the code snippets below we have a move ( constructor & assignment operator ) for <A> class that takes exactly this type ( const A&& ):
https://sololearn.com/compiler-playground/clpEvGacIE71/?ref=app
https://en.cppreference.com/w/cpp/language/cv#mutable_specifier
0
Sounds good MO ELomari . Many thanks for sharing this
One more question.
Const T&& meaning r value ref of const object of T type.
I was misreading it as rvalue ref of type T and const is a nomenclature that function should not be modifying this object.
Correct?
0
yes, const reference mean reference to a const type ( we can also can bind non-const ).
you didn't read it wrong, the purpose of the <const> keyword is to prevent that reference being used to modify the object it is referencing.