#include<stdio.h>

#include<stdlib.h>

#include<time.h>

typedef struct

{

char name[32];

int age;

char gender;

float score[3];

}Student;

typedef struct

{

Student * pData;//学生信息

int size;//容量大小

int count;//当前的记录个数

}Database;

//初始化数据库

int initDatabase(Database* db);

//销毁数据库

void destoryDatabase(Database* db);

//插入一条数据

int insertData(Database* db,Student stu);

//打印数据库的内容

void printDatabase(Database* db);

//随机生成数据

int myrandom(int range)

{

//产生一个range(范围)内的随机数

return rand()%range;

}

int main()

{

//初始化随机数种子

srand((unsigned)time(NULL));

Database db;

//初始化数据库

if(initDatabase(&db)!=0)

{

printf("数据库初始化失败!\n");

return -1;

}

//批量插入数据

for(int i=0; i<20; i++)

{

Student stu;

sprintf(stu.name,"name%d",i);

stu.age = myrandom(30);

stu.gender = myrandom(2) ? 'M' : 'F';

stu.score[0] = myrandom(100);

stu.score[1] = myrandom(100);

stu.score[2] = myrandom(100);

if(insertData(&db,stu) != 0)

{

printf("插入失败!");

break;

}

}

//打印数据库

printDatabase(&db);

//销毁数据库

destoryDatabase(&db);

return 0;

}

//初始化数据库

int  initDatabase(Database* db)

{

db->size = 10;

db->count = 0;

db->pData = (Student*)calloc(db->size,sizeof(Student));

printf("%p\n",db->pData);

if(db->pData != NULL)

{

return 0;

}

return -1;

}

//销毁数据库

void destoryDatabase(Database* db)

{

free(db->pData);

db->pData = NULL;

}

//插入一条数据

int insertData(Database* db,Student stu)

{

//插入前先判断空间是否已满

if(db->count == db->size)//如果满了,要先扩展空间

{

db->size *= 22;//新的空间大小是原来的两倍

//用realloc扩展空间

db->pData = (Student*)realloc(db->pData,db->size*sizeof(Student));

printf("%p\n",db->pData);

if(db->pData == NULL)

{

return -1;

}

}

//插入新纪录

db->pData[db->count] = stu;

db->count++;

return 0;

}

//打印数据库的内容

void printDatabase(Database* db)

{

printf("数据库的大小:%d,现有记录个数:%d\n",db->size,db->count);

printf("  姓名          年龄    性别    数学    语文    英语\n");

for(int i=0; i<db->count; i++)

{

printf("%8s\t%2d\t%c\t%.2f\t%.2f\t%.2f\t\n",

db->pData[i].name,

db->pData[i].age,

db->pData[i].gender,

db->pData[i].score[0],

db->pData[i].score[1],

db->pData[i].score[2]);

}

}

C语言:使用realloc函数对malloc或者calloc动态分配的内存大小进行扩展的更多相关文章

  1. 【转】【C/C++】内存分配函数:malloc,calloc,realloc,_alloca

    转自:http://www.cnblogs.com/particle/archive/2012/09/01/2667034.html#commentform malloc: 原型:extern voi ...

  2. malloc,calloc,realloc函数用法,原理及不同解析

    https://blog.csdn.net/lixungogogo/article/details/50887028 一.malloc malloc在MSDN中原型为: void *malloc( s ...

  3. malloc()函数,calloc()函数,realloc()函数,free()函数

    malloc()函数 头文件:#include <stdlib.h> malloc() 函数用来动态地分配内存空间,其原型为:void* malloc (size_t size); [参数 ...

  4. malloc,calloc,realloc,alloc

    三个函数的申明分别是: void* realloc(void* ptr, unsigned newsize); void* malloc(unsigned size); void* calloc(si ...

  5. malloc()与calloc差别

    Both the malloc() and the calloc() functions are used to allocate dynamic memory. Each operates slig ...

  6. malloc()与calloc区别 (转)

    另外说明: 1.分配内存空间函数malloc 调用形式: (类型说明符*) malloc (size) 功能:在内存的动态存储区中分配一块长度为"size" 字节的连续区域.函数的 ...

  7. malloc()与calloc区别【转】

    转自:http://blog.csdn.net/firecityplans/article/details/4490124/ 版权声明:本文为博主原创文章,未经博主允许不得转载. Both the m ...

  8. malloc()与calloc差异

    Both the malloc() and the calloc() functions are used to allocate dynamic memory. Each operates slig ...

  9. C语言的本质(25)——C标准库之内存管理

    程序中需要动态分配一块内存时怎么办呢?我们可以定义一个缓冲区数组,但是这种方法不够灵活,C89要求定义的数组是固定长度的,而程序往往在运行时才知道要动态分配多大的内存,例如: void foo(cha ...

随机推荐

  1. hdoj1232 畅通工程(并查集)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1232 思路 使用并查集求解. 代码 #include <iostream> #includ ...

  2. 跟厂长学PHP7内核(三):源码目录结构

    上篇文章我们已经介绍了源码分析工具的安装.配置以及调试方法,本文我们来讲述一下PHP源码的目录结构. 一.目录概览 以php-7.0.12为例,看过源码的同学们应该发现源码目录多达十多个,下面是每个目 ...

  3. CodeForces - 620C Pearls in a Row 贪心 STL

    C. Pearls in a Row time limit per test 2 seconds memory limit per test 256 megabytes input standard ...

  4. ONVIF开发实例

    <开发过过程中的经验总结> ➤工具的使用     (1)首先将文件soapClientLib.c 中"代码"的第二行和第三行注释掉,实际上该文件根本没有用,为了保险起见 ...

  5. C# 字符串处理小工具

    之前刚上大学时沉迷于安全方面,当时一直想写一个处理字符串的小程序. 无奈当时没有太多时间,一直拖延到这寒假. 寒假闲来无事,所以就写写小程序来练手,顺便复习一下窗体和基础. 实现的功能有以下: 转换为 ...

  6. 【数论】【扩展欧几里得】Codeforces Round #484 (Div. 2) E. Billiard

    题意:给你一个台球桌面,一个台球的初始位置和初始速度方向(只可能平行坐标轴或者与坐标轴成45度角),问你能否滚进桌子四个角落的洞里,如果能,滚进的是哪个洞. 如果速度方向平行坐标轴,只需分类讨论,看它 ...

  7. windows下整数溢出分析

    0x00前言 整数溢出就是往存储整数的内存单位存放的数据大于该内存单位所能存储的最大值,整数溢出有时候间接导致缓冲区溢出.如JPEG溢出漏洞(MS04-028). 0x01整数溢出分类 整数溢出可以分 ...

  8. SCC缩点

    int V; //顶点数量 vector<int> G[max_v]; //图的邻接表表示方法 vector<int> rG[max_v]; //把边反向建的图 vector& ...

  9. jsoncpp 0.5 ARM移植

    1.下载jsonapp 0.5 https://github.com/open-source-parsers/jsoncpp 2.编译 platform 没有包含 arm 平台,需要把源码提取出来,独 ...

  10. echarts3相关的各种定制化

    在我刚把项目中的echarts从2.x版本升级到echarts3.x,折腾老久,终于交付了项目的时候,echarts4又出来了,先不管,还是把我echarts3.x遇到的和formatter相关的问题 ...