传递参数的c ++内存初始化

时间:2011-11-22 18:57:37

标签: c++

我正在编写一个c ++程序。我正在解析一个文件并初始化一个结构。我有一个数组要初始化,但我必须从文件中读取数组的大小。我想在一个函数中读取数组长度和数组初始化。如果我将数组指针传递给另一个函数并执行一个新函数,当函数返回时,指针将被销毁,我无法看到初始值。这是预期还是我错过了什么。我怎样才能克服这个问题?

3 个答案:

答案 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);