class LinkedList
{
public:
LinkedList() : _head(nullptr) {}
LinkedList(ListElement *newElement) : _head(newElement) {}
~LinkedList() { };
LinkedList(const LinkedList& LL);
LinkedList& operator=(LinkedList byValLinkedList);
private:
ListElement *_head;
}
LinkedList::LinkedList(const LinkedList & LL)
{
ListElement *curr = LL._head;
// If Linked List is empty
if (isEmpty() && curr != nullptr) {
_head = new ListElement(curr->getValue());
curr = curr->getNext();
}
ListElement *newNode = nullptr;
while (curr) {
newNode = new ListElement(curr->getValue());
curr = curr->getNext();
}
}
LinkedList& LinkedList::operator=(LinkedList byValLinkedList)
{
std::swap(_head, byValLinkedList._head);
return *this;
}
int main() {
using namespace std;
LinkedList LL1(new ListElement(7));
//..... some insertions
LinkedList LL2(new ListElement(5));
//..... some insertions
LL1 = LL2; // What is the order ?
// ..... do something else
return 0;
}
Когда выполняется LL1 = LL2, какой из них предполагается вызывать.Почему конструктор копирования вызывается перед назначением копии?
Я ожидаю, что произойдет копирование. Но код был выполнен в следующем порядке
- Конструктор копирования
- Copy-Assignemnt
- Destructor
Что я делаю неправильно? и почему вызвал деструктор?
на основе станд :: своп, я думаю, вы, возможно, на самом деле хотите, чтобы посмотреть в " move constructors "и" move assign ". –