vault backup: 2022-06-09 14:10:26

Affected files:
02. PARA/03. Resources(資源)/C++17/rvalue.md
This commit is contained in:
2022-06-09 14:10:26 +08:00
parent f8e28d70fa
commit fa039f4641

View File

@@ -80,10 +80,47 @@ BigBuffer buf1;
BigBuffer buf2 = buf1; BigBuffer buf2 = buf1;
``` ```
執行訊息:
```
BigBuffer constructor
BigBuffer copy constructor, copy 104857600Bytes
BigBuffer destructor
BigBuffer destructor
```
這會先產生buf1然後把buf1 copy給buf2。如果我們想要省下copy的成本這時候 Move assignment operator就是 `=`)就可以派上用場了。 這會先產生buf1然後把buf1 copy給buf2。如果我們想要省下copy的成本這時候 Move assignment operator就是 `=`)就可以派上用場了。
BigBuffer 加一個 Move assignment operator
```cpp
class BigBuffer {
public:
...
BigBuffer& operator=(BigBuffer&& src) noexcept {
std::cout << "BigBuffer move operator\n";
bufferSize = src.bufferSize;
buffer = std::move(src.buffer);
src.buffer.reset();
src.bufferSize = 0;
return *this;
}
...
```
這個 Move assignment operator 的參數就是一個 rvalue reference我們把來源的 bufferSize 跟 buffer指標「移到」我們這邊而不是完整的複製一份。在轉移之後呢當然也要把來源清空讓轉移更加明確。
有了 Move assignment operator 之後,在執行一次原本的程式,你會發現訊息......沒有變,還是一樣呼叫 copy assignment operator 來複製了100MB的buffer這時我們需要明確的告訴 compiler 我們要「移動」物件,而不是複製它,把原本的程式改為:
```cpp
BigBuffer buf1;
// Do something with buf1
// Assign to buf2
BigBuffer buf2 = std::move(buf1);
```
我們用 `std::move()` 來「移動」物件,這時輸出變成
```
```
## 參考 ## 參考
- [Value categories - cppreference.com](https://en.cppreference.com/w/cpp/language/value_category) - [Value categories - cppreference.com](https://en.cppreference.com/w/cpp/language/value_category)