如何在另一个模板化结构中使用模板化结构(C ++)

时间:2014-01-22 20:46:30

标签: c++ templates types struct typename

我是C / C ++的新手并试图模拟PointRectBound的结构,以允许double和float类型。

这是Point定义

// simple Point structure                                                           
template <typename T, typename U, typename V>                                       
struct Point{                                                                       
    T x;                                                                            
    U y;                                                                            
    V z; // optional                                                                

    /*                                                                              
    Point(){                                                                        
       x = T();                                                                     
       y = U();                                                                     
       z = V();                                                                     
    }*/                                                                             

    Point(T _x, U _y) {                                                             
        x = _x;                                                                     
        y = _y;                                                                     
    }                                                                               

    Point(T _x, U _y, V _z){                                                        
        x = _x;                                                                     
        y = _y;                                                                     
        z = _z;                                                                     
    }                                                                               

    inline bool equals(Point & p){                                                  
        return(p.x == x && p.y == y);                                               
    }                                                                               

};   

这是RectBound结构

// Rectangular Bounds for tree
// T,U should hold double or float only
template <typename T, typename U, typename V>
struct RectBounds {
    // x, y center point   
    T x;
    U y;
    // dimension width w and height h
    T w, h;

    //constructors

    // (_x, _y): center of rectangle bound. (_w, _h): width and height 
    RectBounds(T _x, U _y, T _w, T _h){
        x = _x;
        y = _y;
        w = _w;
        h = _h;
    }

    // returns true if point p is in Rect bounds, false otherwise
    inline bool contains(Point & p) {
        float _w = w/2.0f;
        float _h = h/2.0f;
        return p.x >= x - _w && p.x < x + _w && p.y >= y - _h && p.y < y + _h;
    }

    // returns true if rectangle o intersects this, false otherwise
    inline bool intersects( RectBounds & o){
        float _w = w/2.0f;
        float _h = h/2.0f;
        return !(o.y + o.h/2.0f <= y - _h || o.y - o.h/2.0f >= y + _h || o.x + o.w/2.0f <= x - _w || o.x - o.w/2.0f >= x + _w);
    } 
};

我得到了以下预期的错误:(来自RectBounds倾斜函数的返回行)

error: request for member ‘x’ in ‘p’, which is of non-class type ‘int’
error: request for member ‘x’ in ‘p’, which is of non-class type ‘int’
error: request for member ‘y’ in ‘p’, which is of non-class type ‘int’
error: request for member ‘y’ in ‘p’, which is of non-class type ‘int’

我尝试在RectBounds类中定义一个Point,如下所示

Point<T,U,V> cp;但这没有帮助。

有什么建议吗?

1 个答案:

答案 0 :(得分:2)

首先,您似乎过度复杂了模板。在Point中,xyz可以是不同的类型吗?我猜不是,所以你只需要一个模板参数:

template <typename T>                                       
struct Point{                                                                       
    T x;                                                                            
    T y;                                                                            
    T z;

    // ...
};

RectBounds也应该这样做。

现在,您实际收到错误的原因是由于您的函数containsintersects的参数类型。您使用了PointRectBounds。但是,这些名称是模板,而不是类型。函数参数需要有类型。由于我们现在只给Point一个模板参数,因此类型可能是Point<float>。如您所见,我们需要提供模板参数。所以以下方法可行:

inline bool contains(Point<float> & p) {

但是,您似乎不希望将其修复为某种特定类型。您要么只接受与Point的模板参数类型相同的RectBounds

inline bool contains(Point<T> & p) {

或者您希望能够接受任意类型的Point,在这种情况下,您可以将contains作为成员函数模板:

template <typename U>
inline bool contains(Point<U> & p) {