在翁恺那里学习了c语言可变数组,可是为什么无法正常运行

不知道哪里出错了。。

//main.c
#include<stdio.h>
#include"array.h"

int main()
{
    Array a=array_create(50);
    int i;
    for(i=0;i<=100;i++){
        *array_at(&a,i)=i;
    } 
    printf("此时数组中有%d个元素\n",array_size(&a));
    int cnt=0;
    for(i=0;i<array_size(&a);i++,cnt++){
        printf("%-3d",*array_at(&a,i));
        if(cnt%5==0){
            cnt=0;
            printf("\n");
        }
    }
    array_free(&a);
    return 0;
}

//array.h
typedef struct{
    int *array;
    int size;
}Array; 

Array array_create(int init_size);
void array_free(Array *a);
int array_size(const Array *a);
int *array_at(Array *a,int index);
void array_inflate(Array *a,int more_size);


//array.c

#include"array.h"
#ifndef _ARRAY_H_
#define _ARRAY_H_

const BLOCK_size=20;

Array array_create(int init_size)
{
    Array a;
    a.array=(int*)malloc(sizeof(int)*init_size);
    a.size=init_size;
    return a;
}

void array_free(Array *a)
{
    free(a->array);
    a->array=0;
    a->size=0;
}

int array_size(const Array *a)
{
    return a->size;
}

int *array_at(Array *a,int index)
{
    if(index>=a->size){
        array_inflate(&a,(index/BLOCK_size+1)*BLOCK_size-a->size);
    }
    return &(a->array[index]);
}

void array_inflate(Array *a,int more_size)
{
    int *p=(int*)malloc(sizeof(int)*(a->size+more_size));
    int i;
    for(i=0;i<a->size;i++){
        p[i]=a->array[i];
    }
    free(a->array);
    a->array=p;
}

#endif

代码整体都是对的,唯一错误是69行
array_inflate(&a,(index/BLOCK_size+1)*BLOCK_size-a->size);
第一个参数应该是a,不是&a,因为a已经是Array * 类型了啊,你干嘛又取地址呢?

(1)array_inflate函数的第一个参数类型错误,改成

void array_inflate(Array **a,int more_size);

(2)BLOCK_size没有声明类型,改成:

const int BLOCK_size=20; //这里补充类型

(3)ifndef define endif 这个应该写在.h文件中

img

代码修改如下:

//main.c
#include<stdio.h>

#include"array.h"



int main()
{
    Array a=array_create(50);
    int i;
    for(i=0;i<=100;i++){
        *array_at(&a,i)=i;
    } 
    printf("此时数组中有%d个元素\n",array_size(&a));
    int cnt=0;
    for(i=0;i<array_size(&a);i++,cnt++){
        printf("%-3d",*array_at(&a,i));
        if(cnt%5==0){
            cnt=0;
            printf("\n");
        }
    }
    array_free(&a);
    return 0;
}

//array.h

#ifndef _ARRAY_H_
#define _ARRAY_H_
typedef struct{
    int *array;
    int size;
}Array; 

Array array_create(int init_size);
void array_free(Array *a);
int array_size(const Array *a);
int *array_at(Array *a,int index);
void array_inflate(Array **a,int more_size);

#endif
//array.c

#include"array.h"
#include <stdlib.h>


const int BLOCK_size=20; //这里补充类型

Array array_create(int init_size)
{
    Array a;
    a.array=(int*)malloc(sizeof(int)*init_size);
    a.size=init_size;
    return a;
}

void array_free(Array *a)
{
    free(a->array);
    a->array=0;
    a->size=0;
}

int array_size(const Array *a)
{
    return a->size;
}

int *array_at(Array *a,int index)
{
    if(index>=a->size){
        array_inflate(&a,(index/BLOCK_size+1)*BLOCK_size-a->size);
    }
    return &(a->array[index]);
}

void array_inflate(Array **a,int more_size)
{
    int *p=(int*)malloc(sizeof(int)*((*a)->size+more_size));
    int i;
    for(i=0;i<(*a)->size;i++){
        p[i]=(*a)->array[i];
    }
    free((*a)->array);
    (*a)->array=p;
}



您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632