3

据我所知,C++/C 不支持堆栈上的动态数组。在以下声明中:

int data[n] ; // if the n is not decided at compiling time ,this leads to error

但最近,我读了一些其他人的代码如下:

//**
It seems the n number can not be decided at compling time,but when I run it , if i fprintf the formation, each time i got the correct array size !!!!!!
the G++ version is 4.7.1 
Is this because the G++ 4.7.1 support C++11 x which allow dynamic array?
 **//

#include <cstdio>
#include <algorithm>
using namespace std;

#include <stdio.h>

char s[31];

int Hash()
{
    int sum=0;
    for(int i=0,k=0;k<7;i++)
    {
        if(s[i]>='0'&&s[i]<='9')
        {
            sum*=10;k++;
            sum+=(s[i]-'0');
        }
        else if(s[i]>='A'&&s[i]<'Z')
        {
            sum*=10;k++;
            sum+=((s[i]-'A'-(s[i]>'Q'))/3+2);
        }
    }
    return sum;
}

int main()
{

    int n;scanf("%d",&n);
    int data[n];getchar();
    //fprintf(stderr,"size is %d\n",sizeof(data)/sizeof(data[0]));
    //**
        It seems the n number can not be decided at compling time,but when I run it , if i fprintf the formation, each time i got the correct array size !!!!!!
     *//
    for(int tmp=0;tmp<n;tmp++)
    {
        gets(s);
        data[tmp]=Hash();
    }
    sort(data,data+n);
    bool p=false;n--;
    for(int i=0,num=1;i<n;i+=num=1)
    {
        while(data[i]==data[i+1])
        {
            num++;
            i++;
        }
        if(num>1)
        {
            printf("%03d-%04d %d\n",data[i]/10000,data[i]%10000,num);
            p=true;
        }
    }
    if(!p)printf("No duplicates.\n");
    return 0;
}
4

2 回答 2

7

这些被称为可变长度数组(VLA),是不属于 C++ 标准的 g++ 编译器扩展。如果您希望代码可移植,请不要在 C++ 中使用它。

您可以g++使用编译标志发出警告-Wvla,或使用标志发出错误-Werror=vla。我通常用 编译-pedantic-errors,它捕捉到这个和许多其他与标准的偏差。

于 2013-02-26T09:04:45.760 回答
1

C 和 C++ 是不同的语言。语言之间差异的一个示例是 C确实支持堆栈上的动态数组(尽管C 或 C++ 都不需要堆栈)。它们被称为VLA(可变长度数组)http ://en.wikipedia.org/wiki/Variable-length_array

g++可能具有允许在 C++ 中使用此功能的扩展,但并非所有 C++ 实现都需要该扩展。

于 2013-02-26T09:07:48.270 回答