-1

我的程序如下

#include<stdio.h>

int *intial(int);

int main (void)
{
    int i, *b;

    b=intial(5);
    for(i=0;i<5;i++)
        printf("%d\t",*(b+i));
    getch();
}

int *intial(int t)
{
    int i, *a; 

    for(i=0;i<t;i++)
        a[i]=i;
    return a;
}

但我得到了垃圾值。

我也试过这个

int *intial(int t)
{
    int i, a[10];

    for(i=0;i<t;i++)
        a[i]=i;    
    return a;
}

但它不起作用。

4

2 回答 2

3

为了正常工作,您的函数应为

int *intial(int t)
{
    int i;
    int *a = malloc(t * sizeof(*a));
    if (!a) return NULL; // error checking
    for(i=0;i<t;i++) {
        a[i]=i;
    }
    return a;
}

这个函数的“调用协定”是返回的指针是一个malloc()ed ,调用者有义务free()对它。

当然,调用者也应该进行适当的错误检查:

int main()
{
    int i;
    int *b;
    b=intial(5);
    if (!b) {
        fprintf(stderr, "Malloc error.\n");
        return 1;
    }
    for(i=0;i<5;i++) {
        printf("%d\t",*(b+i)); // *(b+i) should be replaced with b[i] for readability
    }
    free(b); // free the memory
    return 0;
}
于 2013-07-19T10:33:49.507 回答
2

您需要使用 为您的数组分配内存malloc()。否则a, 因此b, 不会特别指向任何东西。

于 2013-07-19T10:24:33.447 回答