没有公共构造函数作为另一个类模板成员的类模板
class template without public constructor as member of another class template
我有一个类模板Shape
,其中包含有关某些形状(可以是三维或二维(的信息。我只希望有几个预定义的形状(立方体、球体和正方形(可用。所有这些预定义的形状都具有相同的属性(因此立方体始终具有相同的体积,我只需要记住一个立方体的属性(。为了禁止某人创建其他Shape
,我使构造函数private
:
// Flag for the possible shapes
enum class Tag
{
SPHERE,
CUBE,
SQUARE
};
template<std::size_t N>
class Shape
{
public:
// Predefined shapes.
static const Shape<3> SPHERE;
static const Shape<3> CUBE;
static const Shape<2> SQUARE;
// Information stored about the given shapes
const Tag tag; // tag specifying the shape
const double v; // Shape volume/area
const std::array<double, 2*N> surrounding_box; // Storing intervals for a surrounding box
//... Some other information that depends on template parameter N
private:
// Private constructor. This prevents other, unintended shapes from being created
Shape(Tag tag, double v, const std::array<double, 2*N> surrounding_box):
tag{tag}, v {v}, surrounding_box {surrounding_box} {};
};
// Initialization of predefined shape: SPHERE
template<std::size_t N>
const Shape<3> Shape<N>::SPHERE(Tag::SPHERE, 3.0,{{0.0,2.7,0.0,2.7,0.0,2.7}});
// Initialization of predefined shape: CUBE
template<std::size_t N>
const Shape<3> Shape<N>::CUBE(Tag::CUBE, 1.0,{{0.0,1.0,0.0,1.0,0.0,1.0}});
// Initialization of predefined shape: SQUARE
template<std::size_t N>
const Shape<2> Shape<N>::SQUARE(Tag::SQUARE, 1.0,{{0.0,1.0,0.0,1.0}});
现在我可以得到一个立方体,作为:
Shape<3> cube = Shape<3>::CUBE;
这似乎工作正常。
当我想将Shape
实例作为另一个类模板的成员时出现问题Object
.具体来说,我无法为我的Object
类模板编写正常工作的构造函数:
template <std::size_t N>
class Object
{
public:
Object(Tag shape_tag, double weight, double elevation):
weight {weight}, elevation {elevation}
{
switch(shape_tag)
{
case Tag::CUBE:
{
shape = Shape<3>::CUBE;
break;
}
case Tag::SPHERE:
{
shape = Shape<3>::SPHERE;
break;
}
case Tag::SQUARE:
{
shape = Shape<2>::SQUARE;
break;
}
}
}
private:
Shape<N> shape;
double weight;
double elevation;
};
创建Object
为
Object<3> object(Tag::CUBE, 1.0,1.0);
失败,编译器错误error: no matching function for call to ‘Shape<3ul>::Shape()’
。 我认为,因为我不使用初始值设定项列表来shape
,Object
的构造函数尝试调用默认构造函数Shape()
,这是不可用的。 我还尝试将构造的Shape
部分移动到单独的初始化函数,然后我可以在初始值设定项列表中调用该函数。但是,在这种情况下,模板部分不断生成不同的问题(因为我需要能够同时初始化Shape<2>
和Shape<3>
对象(。
我该如何解决这个问题?或者是否有更好的方法来确保只有一些预定义的Shape
可用,而不使其构造函数私有?
附言。这里介绍的形状和对象的问题只是一个MWE。
创建工厂:
template <std::size_t N> Shape<N> MakeShape(Tag shape_tag);
template <>
Shape<3> MakeShape(Tag shape_tag)
{
switch(shape_tag)
{
case Tag::CUBE: return Shape<3>::CUBE;
case Tag::SPHERE: return Shape<3>::SPHERE;
}
throw std::runtime_error("Invalid tag");
}
template <>
Shape<2> MakeShape(Tag shape_tag)
{
switch(shape_tag)
{
case Tag::SQUARE: return Shape<3>::SQUARE;
}
throw std::runtime_error("Invalid tag");
}
然后
template <std::size_t N>
class Object
{
public:
Object(Tag shape_tag, double weight, double elevation):
shape{MakeShape<N>(shape_tag)}, weight {weight}, elevation {elevation}
{
}
};
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何从另一个文件继承私有成员变量和公共函数
- C++-我可以创建另一个类的成员并在构造函数中使用它吗
- 在作为静态成员包含在另一个类中的类的构造函数中使用 cout
- 为什么将一个结构的引用设置为等于另一个结构只会更改一个数据成员?
- 没有公共构造函数作为另一个类模板成员的类模板
- 将另一个类的对象传递到当前类C++的构造函数中(不是成员初始化)
- 将类成员函数作为线程调用到另一个类成员函数时发出警告消息
- 如何使用另一个类中的公共成员函数作为参数调用线程
- 是否可以使用智能指针成员设置具有另一个结构的结构?
- 使用指向成员函数的指针在另一个类中调用类构造函数
- 访问 std:vector 的类成员 std:vector 在一个类中与另一个 std:vector
- 无法将指向类的成员函数的函数指针作为参数传递给同一类的另一个成员函数
- 复制赋值函数如何访问另一个对象的私有成员(Stroustroup 原则和实践书)?
- 如何从另一个嵌套类中调用某个封闭类的嵌套类的函数指针成员的值?
- 在C++中,是否可以"overload"作为另一个类成员的对象?
- C++ - 非静态 void* 成员,指向具有相同地址但不同值的不同对象的另一个非静态成员
- 如何检查一个模板是否是另一个模板的类成员
- 如何在另一个类中使用类成员的正确方法?