我想为 3x3 矩阵制作自己的结构。我想允许通过组件/元素或“行”进行构造。
所以要么你提供一个std::array<float, 9>
或一个std::array<std::array<float, 3>, 3>
但是,当使用以下构造函数定义这样的结构时:
struct Matrix3x3
{
Matrix3x3(std::array<float, 9> components) { }
Matrix3x3(std::array<std::array<float, 3>, 3> rows) { }
};
那么第二个构造函数与第一个构造函数有歧义。这意味着您可以像这样调用第二个构造函数
Matrix3x3{ {{ {{1.f, 2.f, 3.f}}, {{4.f, 5.f, 6.f}}, {{7.f, 8.f, 9.f}} }} };
没有任何问题,但是像这样调用第一个构造函数
Matrix3x3{ {{1.f, 2.f, 3.f, 4.f, 5.f, 6.f, 7.f, 8.f, 9.f}} };
将给出以下消息和错误:
message : No constructor could take the source type, or constructor overload resolution was ambiguous
error C2440: '<function-style-cast>': cannot convert from 'initializer list' to 'ArrayTest'
Visual Studio 告诉我“有多个构造函数实例......与参数列表匹配”。
我测试了做同样的事情,但使用了一个整数数组(因为它更容易使用)和一个长度。考虑:
struct ArrayTest
{
ArrayTest(std::array<int, 1> arrayOfInts) { }
ArrayTest(std::array<std::array<int, 1>, 1> arrayOfArraysOfInts) { }
};
然后前 3 个有效并为第一个构造函数编译,而所有 5 个为第二个构造函数编译。
auto test1 = ArrayTest{ {1} };
auto test2 = ArrayTest{ { {1} } };
auto test3 = ArrayTest{ { { {1} } } };
auto test4 = ArrayTest{ { { { {1} } } } };
auto test5 = ArrayTest{ { { { { {1} } } } } };
对于简单的数组构造函数“test3”是完整的初始化,其中第一对括号初始化聚合 ArrayTest,第二对初始化数组,第三对初始化该数组的第一个元素,最后第四个括号初始化整数 1 很少见,但有效。“test1”和“test2”只是“test3”的大括号省略版本。
对于 array-of-arrays 构造函数,“test5”是完整的初始化,所有其他的都是大括号省略的。这就是造成歧义的原因。
所以问题是:我该如何解决这个问题?还是有更好的方法/解决方案?