c++ - 模板友元函数无法访问私有(private)成员

标签 c++

我正在尝试在vc6上编译本书第三版上的程序。它发现这 3 个友元函数无法访问私有(private)成员。我删除了友元函数声明中运算符==后面的<>,因为它无法通过语法检查。

这可能是一个众所周知的问题,我猜这可能是由于友元函数名称不匹配,但我只是不知道如何纠正它。请帮助我解决这个问题。谢谢 代码如下:

   // Program to test slices and a simple N*M matrix class

// pp 670-674 and 683-684

// No guarantees offered. Constructive comments to <a href="https://stackoverflow.com/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="284a5b685a4d5b4d495a4b4006495c5c064b4745" rel="noreferrer noopener nofollow">[email protected]</a>


#include<iostream>
#include<valarray>
#include<algorithm>
#include<numeric>   // for inner_product
using namespace std;

// forward declarations to allow friend declarations:
template<class T> class Slice_iter;
template<class T> bool operator==(const Slice_iter<T>&, const Slice_iter<T>&);
template<class T> bool operator!=(const Slice_iter<T>&, const Slice_iter<T>&);
template<class T> bool operator< (const Slice_iter<T>&, const Slice_iter<T>&);

template<class T> class Slice_iter {
    valarray<T>* v;
    slice s;
    size_t curr;    // index of current element

    T& ref(size_t i) const { return (*v)[s.start()+i*s.stride()]; }
public:
    Slice_iter(valarray<T>* vv, slice ss) :v(vv), s(ss), curr(0) { }

    Slice_iter end() const
    {
        Slice_iter t = *this;
        t.curr = s.size();  // index of last-plus-one element
        return t;
    }

    Slice_iter& operator++() { curr++; return *this; }
    Slice_iter operator++(int) { Slice_iter t = *this; curr++; return t; }

    T& operator[](size_t i) { return ref(i); }      // C style subscript
    T& operator()(size_t i) { return ref(i); }      // Fortran-style subscript
    T& operator*() { return ref(curr); }            // current element

    friend bool operator==(const Slice_iter<T>& p, const Slice_iter<T>& q);
    friend bool operator!=(const Slice_iter<T>& p, const Slice_iter<T>& q);
    friend bool operator< (const Slice_iter<T>& p, const Slice_iter<T>& q);

};


template<class T>
bool operator==(const Slice_iter<T>& p, const Slice_iter<T>& q)
{
    return p.curr==q.curr && p.s.stride()==q.s.stride() && p.s.start()==q.s.start();
}

template<class T>
bool operator!=(const Slice_iter<T>& p, const Slice_iter<T>& q)
{
    return !(p==q);
}

template<class T>
bool operator<(const Slice_iter<T>& p, const Slice_iter<T>& q)
{
    return p.curr<q.curr && p.s.stride()==q.s.stride() && p.s.start()==q.s.start();
}

由于我无法在评论中添加大量文字,因此我在 vs2008 中发布了一些错误。很明显,之前的错误是由于vc6造成的,非常感谢。 完整的代码在这里:http://www2.research.att.com/~bs/matrix.c 看来这些语法错误与friend函数无关,而是与数字中的inner_product有关。 Visual Studio 2008下的一些错误消息:

1>c:\vc2008\vc\include\xutility(764) : error C2039: 'iterator_category' : is not a member of 'Cslice_iter<T>'
1>        with
1>        [
1>            T=double
1>        ]
1>        c:\vc2008\vc\include\numeric(106) : see reference to class template instantiation 'std::iterator_traits<_Iter>' being compiled
1>        with
1>        [
1>            _Iter=Cslice_iter<double>
1>        ]
1>        k:\c++\valarray0.cpp(245) : see reference to function template instantiation 'double std::inner_product<Cslice_iter<T>,_Ty*,double>(_InIt1,_InIt1,_InIt2,_Ty)' being compiled
1>        with
1>        [
1>            T=double,
1>            _Ty=double,
1>            _InIt1=Cslice_iter<double>,
1>            _InIt2=double *
1>        ]
1>c:\vc2008\vc\include\xutility(764) : error C2146: syntax error : missing ';' before identifier 'iterator_category'
1>c:\vc2008\vc\include\xutility(764) : error C4430: missing type specifier - int assumed. Note: C++ does not support default-int
1>c:\vc2008\vc\include\xutility(764) : error C2602: 'std::iterator_traits<_Iter>::iterator_category' is not a member of a base class of 'std::iterator_traits<_Iter>'
1>        with

最佳答案

您必须在类定义中声明为友元时指定类型参数。

此外,您不需要指定 Slice_iter<T>Slice_Iter类范围内隐式具有类型参数。

 friend bool operator==<T>(const Slice_iter& p, const Slice_iter& q);
 friend bool operator!=<T>(const Slice_iter& p, const Slice_iter& q);
 friend bool operator< <T>(const Slice_iter& p, const Slice_iter& q);

关于c++ - 模板友元函数无法访问私有(private)成员,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6838924/

相关文章:

c++ - 如何从 C++ 定义中获取编译日期?

c++ - 如果存在从 `double`到 `T`的转换,SFINAE禁用构造函数

c++ - 删除可能保存在两个不同地方的数据

c++ - 我应该通过 const 引用传递一个 lambda。

python - 使用 boost::python 包装 boost::optional

c++ - 如何将 ascii 字符转换为十六进制... C++ 中的东西?

c++ - 打印半金字塔

c++ - 标准库或编译器在哪里利用 noexcept move 语义( vector 增长除外)?

c++ - Gtk::StatusIcon 系统托盘对齐问题

c++ - 二维容器结构数组的构造函数