目前我有以下课程
//AABB.h
class AABB {
public:
template <class T>
AABB(const std::vector<T>& verties);
template <class T>
AABB(const std::vector<int>& indicies, const std::vector<T>& verties);
template <class T>
AABB(const std::vector<int>::const_iterator begin,
const std::vector<int>::const_iterator end,
const std::vector<T>& verties);
AABB();
AABB(const vec3 min, const vec3 max);
AABB(const AABB& other);
const vec3& min_p() const { return m_min; }
const vec3& max_p() const { return m_max; }
vec3 center();
float volume();
float surface_area();
bool inside(vec3 point);
float intersect(const Ray& ray);
private:
vec3 m_min;
vec3 m_max;
};
有三个AABB
构造函数是模板化的。有可能我可以声明使用显式实例化吗?如下所示?
// AABB.cpp
template AABB::AABB<Triangle>(const idx_t, const idx_t, const vector<Triangle>&);
给定的
// AABB.cpp
using idx_t = std::vector<int>::const_iterator;
目前编译器的错误是
/Users/DarwinSenior/Desktop/cs419/tracer2/src/AABB.cpp:7:16: error: qualified
reference to 'AABB' is a constructor name rather than a type wherever a
constructor can be declared
template AABB::AABB<Triangle>(const idx_t, const idx_t,
^
答案 0 :(得分:1)
你几乎就在那里,问题是最后一个参数必须是模板声明中的引用:
template AABB::AABB<Triangle>(const idx_t, const idx_t, const vector<Triangle>&);
// ^^^
另外,正如T.C指出的那样,您可以删除<Triangle>
,因为它可以从参数的类型推断出来:
template AABB::AABB(const idx_t, const idx_t, const vector<Triangle>&);
答案 1 :(得分:0)
您无法明确定义模板构造函数的类型 相反,它们将从参数中定义。
例如,请考虑以下代码:
struct S {
template<typename T>
S(T t) { }
};
// ...
S s{'c'}
在这里,您实际上并不需要指定类型,而是从参数中定义为char
。