Here you can see copy assignment operator implementation with self assignment check:
String & operator=(const String & s)
{
    if (this != &s)
    {
        String(s).swap(*this); //Copy-constructor and non-throwing swap
    }
    // Old resources are released with the destruction of the temporary above
    return *this;
}
This is good for self assignment, but bad for performance:
So I still don't understand if I would implement std::vector's operator= how I would implement it.
Yes, this code is superflous. And it is true that it is causing extra unncessary branch. With proper swap and move semantics, following should be much more performant:
String& String::operator=(String s) { // note passing by value!
    std::swap(s, *this); // expected to juggle couple of pointers, will do nothing for self-assingment
    return *this;
}
Also note, it is more benefical to accept the argument by value.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With