我正在编写一个c ++程序。我正在解析一个文件并初始化一个结构。我有一个数组要初始化,但我必须从文件中读取数组的大小。我想在一个函数中读取数组长度和数组初始化。如果我将数组指针传递给另一个函数并执行一个新函数,当函数返回时,指针将被销毁,我无法看到初始值。这是预期还是我错过了什么。我怎样才能克服这个问题?
答案 0 :(得分:7)
你通过忘记手动数组,原始指针传递*和new
的所有内容来克服这个问题。这是C ++,而不是1991年。所以,一个典型的解决方案可能就是这样:
#include <vector>
#include <cstdint>
#include <istream>
std::vector<uint32_t> read_data(std::istream & is)
{
uint32_t len;
is.read(reinterpret_cast<char*>(&len), sizeof(uint32_t));
std::vector<uint32_t> result(len);
for (uint32_t i = 0; i != len; ++i)
{
is.read(reinterpret_cast<char*>(&result[i]), sizeof(uint32_t));
}
return result;
}
(在高质量代码中,read
命令将被条件包围,并且可能会通过抛出异常来处理错误。)
随后:
#include "int_reader.hpp"
#include <fstream>
#include <iostream>
int main()
{
std::ifstream infile("thedata.bin", std::ios::binary);
std::vector<uint32_t> data = read_data(infile);
std::cout << "We read " << data.size() << " integers.\n";
}
*)当用于I / O操作时,在通用C ++中具有位置的唯一原始指针是char*
,如此代码所示。 C ++将char
定义为机器的基本数据单元类型,I / O以char
为单位进行。
答案 1 :(得分:1)
在致电new
之前没有数组指针。所以你无法将它传递给函数。
您正在做的就是将数组指针的未初始化的垃圾值传递给函数。该函数使用从new
返回的正确指针覆盖其垃圾值的副本,但原始函数永远不会看到该指针。
您需要将函数传递给指针。然后当它调用new
时,它可以使用指向指针的指针来更新调用者的指针。像这样:
void SomeFunction(void **SomePointer)
{
(*SomePointer) = malloc(1024);
}
void *MyPointer;
SomeFunction(&MyPointer);
答案 2 :(得分:1)
您必须将指针传递给指针才能让函数为您分配
void allocateArrayOfT(T** objArray, size_t len) {
*objArray = new T[len];
}
您可以致电:
T* arrayPtr;
allocateArrayOfT(&arrayPtr, len);