在MS Visual C ++中启用VLA(可变长度数组)?

如何在MS Visual C ++中启用使用C99中定义的VLA或可变长度数组,或者根本不可能?

是的我知道C ++标准是基于C89的,并且VGA在C89标准中不可用,因此在C ++中不可用,但MSVC ++也应该是C编译器,可以使用/ TC编译器参数( Compile as C Code (/TC) )。 但这样做似乎并没有启用VLA,并且编译过程在构建为C ++( Compile as C++ Code (/TP) )时会出现相同的错误。 也许MSVC ++ C编译器只符合C89或者我缺少一些东西(一些特殊的构造或pragma / define)?

代码示例:

 #include  int main(int argc, char **argv) { char pc[argc+5]; /* do something useful with pc */ return EXIT_SUCCESS; } 

编译错误:

错误C2057:预期的常量表达式

错误C2466:无法分配常量大小为0的数组

错误C2133:’pc’:未知大小

MSVC不是C99编译器,并且不支持可变长度数组。

在https://docs.microsoft.com/en-us/cpp/c-language/ansi-conformance中, MSVC被记录为符合C90。

VLA更易于编写,但当std::vector的动态内存分配过高时,您可以使用alloca()获得类似的行为。

http://msdn.microsoft.com/en-us/library/x9sx5da1.aspx

在您的示例中使用alloca()将给出:

 #include  #include  int main(int argc, char **argv) { char* pc = (char*) alloca(sizeof(char) * (argc+5)); /* do something useful with pc */ return EXIT_SUCCESS; } 

我遇到了同样的问题,这在MS Visual C ++ 2015中是不可能的,相反你可以使用vector做几乎相同的,唯一的区别是堆资源管理例程(new / delete)的可忽略的开销。

虽然VLA很方便,但是从堆栈中分配非确定性内存量有堆栈溢出的风险通常不是一个好主意。