我正在使用其他人编写的一些现有代码,我无法编译(这里有限的C经验,但我正在努力学习!)。
utilities.cc
#include "utilities.h"
FILE *open_file(char *filename, const char*extension, const char *access)
{
char string[MAX_STR_LEN];
FILE *strm = NULL;
if(filename[0]=='\0')
{
printf("\n INPUT FILENAME (%s) > ",access);
fgets(string,MAX_STR_LEN,stdin);
sscanf(string,"%s",filename);
printf(" FILE %s opened \n", filename);
}
int len=strlen(filename);
if( len + strlen(extension) >= MAX_STR_LEN)
{
printf("\n ERROR: String Length of %s.%s Exceeds Maximum",
filename, extension);
return(NULL);
}
// char *filename1 = new(char[len+strlen(extension)+1]);
const int filenameLength = len+strlen(extension)+1;
char *filename1 = new(char[filenameLength]);
strcpy(filename1,filename); // temp filename for appending extension
/* check if file name has .extension */
/* if it does not, add .extension to it */
int i=len-1;
while(i > 0 && filename[i--] != '.');
// printf("\n Comparing %s to %s", extension, filename+i+1);
if(strcmp(extension, filename+i+1) )
strcat(filename1,extension);
if( (strm = fopen(filename1, access) ) == NULL )
{
printf("\n ERROR OPENING FILE %s (mode %s)", filename1,access);
}
delete(filename1);
return(strm);
}
这是错误。
Compiling utilities.cc ...
src/utilities.cc: In function ‘FILE* open_file(char*, const char*, const char*)’:
src/utilities.cc:251: error: ISO C++ forbids variable-size array
gmake: *** [/home/landon/geant4/work/tmp/Linux-g++/exampleN01/utilities.o] Error 1
第251行的错误指的是
char *filename1 = new(char[filenameLength]);
如果您需要任何其他信息,请告诉我们。
答案 0 :(得分:23)
错误是正确的。在C ++中禁止使用VLA(可变大小的数组)。这是一个VLA:
char filename1char[filenameLength];
你的意思是:
char *filename1 = new char[filenameLength];
哪个不是VLA,而是在堆上分配的char
数组。请注意,您应该使用operator delete[]
删除此指针:
delete[] filename1;
答案 1 :(得分:13)
试试这个
char *filename1 = new char[filenameLength];
你不能像这样
在堆栈上创建一个数组作为局部变量长度数组 char filename1[filenamelength];
除非filenamelength
被声明为const
。
此外,由于您已为阵列分配了内存,因此应使用
释放内存 delete [] filename1;
否则你会有内存泄漏。此外,在return
值附近加上括号并非必不可少;
答案 2 :(得分:2)
它们是被禁止的,但解决方法是使用堆栈分配器,例如:
http://howardhinnant.github.io/stack_alloc.html
您可以将堆栈分配器与::std::vector
(或其他容器,或直接使用)一起使用,并且您自己拥有VLA
。