// I need to download data from the (json-format) file net_f:
std::ifstream net_f("filename", std::ios::in | std::ios::binary);
// to a square int array *net of size n:
int n;
int * net;
load_net(net_f, &n, net);
// The size is initially unknown, so I want to do it in the procedure:
void load_net(std::ifstream& f, int *n, int *net)
{
int size; // # of rows (or columns, it's square) in the array
int net_size; // the array size in bytes
/*
some code here to process data from file
*/
// Returning values:
*n = size;
// Only now I am able to allocate memory:
*net = (int *)malloc(net_size);
/*
and do more code to set values
*/
}
Теперь: компилятор предупреждает меня, что «переменная« сеть »используется до того, как ее значение установлено». Действительно, это потому, что у меня недостаточно информации. Он также всплывает во время выполнения, и я просто игнорирую его. Как я должен переделать свой код, чтобы сделать его более элегантным? (BTW это должен быть массив, а не вектор, я копирую его на устройство CUDA).C++ как передать неинициализированный указатель на функцию
Что это должно означать: '* net = (int *) malloc (net_size);' при условии, что выражение RHS передается в 'int *', а выражение LHS - 'int'? – juanchopanza
http://stackoverflow.com/questions/2838038/c-programming-malloc-inside-another-function – jamesdlin