Ошибка компоновки в функции-другом класса шаблона

У меня есть узел класса шаблона и для того, чтобы следовать идиоме копирования и замены, я пытаюсь написать swap функция, которая является friend класса Node

мой код:

Node.h

#ifndef NODE_H
#define NODE_H

#include<memory>
template<typename type>
class Node
{
    type data_;
    std::unique_ptr<Node> next_;
public:
    Node(type data);
    Node(const Node& other);
    Node& operator=(Node other);
    friend void swap(Node& lhs, Node& rhs);
};

#include "Node.tpp"
#endif

и Node.tpp

template<typename type>
Node<type>::Node(type data):data_(data),next_(nullptr){
}

template<typename type>
Node<type>::Node(const Node& other)
{
    data_ = other.data_;
    next_ = nullptr;
    if(other.next_ != nullptr)
    {
        next_.reset(new Node(other.next_->data_));
    }
}
template<typename type>
void swap(Node<type>& lhs, Node<type>& rhs)
{
    using std::swap;
    swap(lhs.data_,rhs.data_);
    swap(lhs.next_,rhs.next_);
}

template<typename type>
Node<type>& Node<type>::operator=(Node other)
{
    swap(*this,other);
    return *this;
}

когда я проверю это из Source.cpp

#include "Node.h"
int main()
{
    Node<int> n(3);
    Node<int> n2(n);
    Node<int> n3(5);
    n3 = n2;
}

я получаю следующую ошибку связывания:

LNK2019: unresolved external symbol "void __cdecl swap(class Node<int> &,class Node<int> &)

1 ответ

Решение

Объявление друга не "наследует" параметр шаблона, но нуждается в своем собственном:

template<typename type>
class Node
{
    // ...
public:
    // ...
    template<typename U> // <<<<<<<<<<<
    friend void swap(Node<U>& lhs, Node<U>& rhs);
                      // ^^^           ^^^
    // ...
};
Другие вопросы по тегам