Ext*_*kun 1 c++ dynamic-arrays
我有这段代码,我正在考虑简化:
if (numberOfResults > 1)
{
trackResult_ = new TrackResult[numberOfResults];
for (int i=0; i < numberOfResults; i++)
{
// Make a deep copy
TrackResult tempResult = result[i];
TrackResult * clone = new TrackResult(tempResult);
trackResult_[i] = *clone;
}
storeJointResults(trackResult_, numberOfResults);
}
else
{
trackResult_ = new TrackResult(*result);
}
Run Code Online (Sandbox Code Playgroud)
(我没有选择,只能在这里使用一个简单的动态数组.在我的工作场所,向量被认为'过于复杂')
我想知道我是否可以逃脱
// even if we just have one result, we init an array size of one
trackResult_ = new TrackResult[numberOfResults];
Run Code Online (Sandbox Code Playgroud)
但是,我已经在几个点检查结果的数量并采取相应的行动
if (numberOfResults_ == 1)
{
velocity = trackResult_.velocity;
}
Run Code Online (Sandbox Code Playgroud)
这些代码仍然有效吗?如果没有,为什么?
大小为1的数组不需要是特殊情况.
分配动态数组时,会给出指向第一个元素的指针.如果数组的大小为1,那么与分配对象的单个实例几乎无法区分.
如果您更改了特殊用例,则可以使用.到 - >但是我建议不要特殊包装它,只需使用trackResult_ [0] .velocity