【发布时间】:2022-01-02 02:36:53
【问题描述】:
我有以下声明和函数调用:
unsigned int myArray[5] = {0, 0, 0, 0, 0};
ModifyArray(&myArray[0]);
以上代码不能修改,按原样给出。
我需要编写 ModifyArray 的实现来更新 myArray 以包含 1、2、3、4、5。
我把它写成:
void ModifyArray(unsigned int * out_buffer)
{
unsigned int updatedValues[5] = {0, 0, 0, 0, 0};
updatedValues[0] = 1;
updatedValues[1] = 2;
updatedValues[2] = 3;
updatedValues[3] = 4;
updatedValues[4] = 5;
*out_buffer = &updatedValues;
}
这似乎不起作用。我有一种感觉,我没有在最后一行代码上正确地进行赋值,但是我尝试了多种变体,但它似乎仍然没有只更新数组的元素 0。
我做错了什么?谢谢!
P.S.:请注意,场景比这里介绍的要复杂。为了便于阅读,我已经进行了简化,但代码看起来应该与此非常相似,如果可能的话,应该将最后一个分配更新为正确的。
【问题讨论】:
-
*out_buffer = &updatedValues;您需要将新值复制到旧数组中。但实际上,根本不需要updatedValues。直接使用out_buffer即可。 -
为什么不直接将值设置为
out_buffer的元素? -
要么直接将更新后的值设置为
out_buffer,而无需绕过updatedValues,或者使用std::memcpy。另请记住,您的函数需要知道数组长度。 -
您不能分配 C 样式的数组。 (您可以使用任意数量的方法复制一个,但
=不是其中之一)。不过,目前尚不清楚为什么需要一个中间数组。 “我的代码更复杂”不是一个有效的借口。 -
"上面的代码不能修改" 可惜签名不好
(unsigned int * out_buffer, int size)orunsigned int (& out)[5]orstd::span<unsigned int, 5>会更好。
标签: c++ arrays function pointers parameters