C语言:使用realloc函数对malloc或者calloc动态分配的内存大小进行扩展
#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动态分配的内存大小进行扩展的更多相关文章
- 【转】【C/C++】内存分配函数:malloc,calloc,realloc,_alloca
转自:http://www.cnblogs.com/particle/archive/2012/09/01/2667034.html#commentform malloc: 原型:extern voi ...
- malloc,calloc,realloc函数用法,原理及不同解析
https://blog.csdn.net/lixungogogo/article/details/50887028 一.malloc malloc在MSDN中原型为: void *malloc( s ...
- malloc()函数,calloc()函数,realloc()函数,free()函数
malloc()函数 头文件:#include <stdlib.h> malloc() 函数用来动态地分配内存空间,其原型为:void* malloc (size_t size); [参数 ...
- malloc,calloc,realloc,alloc
三个函数的申明分别是: void* realloc(void* ptr, unsigned newsize); void* malloc(unsigned size); void* calloc(si ...
- malloc()与calloc差别
Both the malloc() and the calloc() functions are used to allocate dynamic memory. Each operates slig ...
- malloc()与calloc区别 (转)
另外说明: 1.分配内存空间函数malloc 调用形式: (类型说明符*) malloc (size) 功能:在内存的动态存储区中分配一块长度为"size" 字节的连续区域.函数的 ...
- malloc()与calloc区别【转】
转自:http://blog.csdn.net/firecityplans/article/details/4490124/ 版权声明:本文为博主原创文章,未经博主允许不得转载. Both the m ...
- malloc()与calloc差异
Both the malloc() and the calloc() functions are used to allocate dynamic memory. Each operates slig ...
- C语言的本质(25)——C标准库之内存管理
程序中需要动态分配一块内存时怎么办呢?我们可以定义一个缓冲区数组,但是这种方法不够灵活,C89要求定义的数组是固定长度的,而程序往往在运行时才知道要动态分配多大的内存,例如: void foo(cha ...
随机推荐
- jenkins备份与恢复
jenkins这里我通过thinbackup插件进行对jenkins的配置备份与恢复 1丶安装thinbackup插件 2丶系统管理选择thinbackup插件 3丶创建备份目录 mkdir /bac ...
- php输出多余的空格或者空行
1,文件是否有bom.可以通过脚步检测,或者利用notepa++打开,查看编码格式. 2. <?php echo 'something'; ?> 或许是你的php标签外,有空格或者空行 ...
- MyISAM InnoDB 区别(转载)
MyISAM 和 InnoDB 讲解 InnoDB和MyISAM是许多人在使用MySQL时最常用的两个表类型,这两个表类型各有优劣,视具体应用而定.基本的差别为:MyISAM类型不支持事务处理等高级处 ...
- ARKit:增强现实技术在美团到餐业务的实践
前言 增强现实(Augmented Reality)是一种在视觉上呈现虚拟物体与现实场景结合的技术.Apple 公司在 2017 年 6 月正式推出了 ARKit,iOS 开发者可以在这个平台上使用简 ...
- FGPA 中的计数器Verilog语言(时钟分频器)
在quartusII8.0中为ALTERAFPGA设置一个分频器(计数器) 输入时钟48Mhz 输出时钟9600HZ /* 实验名称: 计数器 ** 程序功能: 将48Mhz的时钟分频为9600Hz ...
- python opencv3 背景分割 mog2 knn
git:https://github.com/linyi0604/Computer-Vision 使用mog2算法进行背景分割 # coding:utf-8 import cv2 # 获取摄像头对象 ...
- N!(N的阶乘)最末位非0的求解方法
问题是求关于N!的最后一位非0位, 如3!=6,最后一位非0位为6, 5!=120, 最后一位非0位为2.怎么样快速的求出最后一位非0位呢? 最朴素的想法就是先求出N!的结果,再求出结果的最后一位非0 ...
- 【BZOJ-1194】潘多拉的盒子 拓扑排序 + DP
1194: [HNOI2006]潘多拉的盒子 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 456 Solved: 215[Submit][Stat ...
- 更好的浏览器动画实现 requestAnimationFrame
requestAnimationFrame 是专门为实现高性能的帧动画而设计的一个API: js一般是借助setTimeout或setInterval这两个函数实现动画,性能不佳. css3动画,性能 ...
- 【转载】HTTP/FTP客户端开发库:libwww、libcurl、libfetch
网页抓取和ftp访问是目前很常见的一个应用需要,无论是搜索引擎的爬虫,分析程序,资源获取程序,WebService等等都是需 要的,自己开发抓取库当然是最好了,不过开发需要时间和周期,使用现有的Ope ...