使用模板函数打印智能指针矢量



我写了一个函数来打印给定的vector

template <typename T>
void print_vector(std::string text, std::vector<T> &vect){
    std::cout << ">>>>>>>>>> " << text << " <<<<<<<<<<" << std::endl;
    for(T &t: vect){
        std::cout << t << ", ";
    }
    std::cout << std::endl << "--------------------" << std::endl;
}

但是当我给函数一个shared_ptr vector时,它会打印地址,而不是指向的值。

当元素是shared_ptr时,有没有办法打印值..?
我尝试了以下方法,但它给了我一个编译错误,我不知道如何解决它。

template <typename T, typename F>
void print_vector(std::string text, std::vector<T> &vect){
    std::cout << ">>>>>>>>>> " << text << " <<<<<<<<<<" << std::endl;
    for(T &t: vect){
        if(std::is_same<T, std::shared_ptr<F>>::value) {
            std::cout << *t << ", ";
        } else {
            std::cout << t << ", ";
        }
    }
    std::cout << std::endl << "--------------------" << std::endl;
}

重载函数以获取智能指针的向量。

template <typename T>
void print_vector(std::string text, std::vector<T> &vect){
    std::cout << ">>>>>>>>>> " << text << " <<<<<<<<<<" << std::endl;
    for(T &t: vect){
        std::cout << t << ", ";
    }
    std::cout << std::endl << "--------------------" << std::endl;
}
template <typename T>
void print_vector(std::string text, std::vector<std::shared_ptr<T>> &vect){
    std::cout << ">>>>>>>>>> " << text << " <<<<<<<<<<" << std::endl;
    for(auto &t: vect){
        std::cout << *t << ", ";
    }
    std::cout << std::endl << "--------------------" << std::endl;
}

如果您有更多希望打印不同内容的情况,您可能会发现某些重载不明确,您可能必须在它们应该相互匹配时禁用不明确的模板。

您可以重载运算符shared_ptr查看以下代码:

template<typename T>
ostream& operator<<(ostream& out, const shared_ptr<T>& s_ptr)
{
    if (s_ptr != nullptr)
        out << (*s_ptr);
    return out;
}
template <typename T>
void print_vector(std::string text, std::vector<T> &vect){
    std::cout << ">>>>>>>>>> " << text << " <<<<<<<<<<" << std::endl;
    for(T &t: vect){
        std::cout << t << ", ";
    }
    std::cout << std::endl << "--------------------" << std::endl;
}

您希望重载流运算符以进行shared_ptr,这可以针对特定类型或所有类型的:

template <typename T>
std::ostream& operator << (std::ostream& os, const std::shared_ptr< T >& p)
{
  if ( p )
  {
    os << *p;
  }
  else
  {
    os << "<null>";
  }
  return os;
}

只需重载函数模板:

template <typename T>
void print_vector(std::string text, std::vector<T> &vect){
    std::cout << ">>>>>>>>>> " << text << " <<<<<<<<<<" << std::endl;
    for(T &t: vect){
        std::cout << t << ", ";
    }
    std::cout << std::endl << "--------------------" << std::endl;
}
template <typename T>
void print_vector(std::string text, std::vector<std::shared_ptr<T>> &vect) {
    std::cout << ">>>>>>>>>> " << text << " <<<<<<<<<<" << std::endl;
    for(auto &t: vect){
        std::cout << *t << ", ";
    }
    std::cout << std::endl << "--------------------" << std::endl;
}

现在它将处理这两种情况。

相关内容

  • 没有找到相关文章

最新更新