动态数组的建立

[复制链接]
查看11 | 回复5 | 2013-7-31 11:52:24 | 显示全部楼层 |阅读模式
如果一定要是数组不是链表的话 用下面的函数extern void *realloc(void *mem_address, unsigned int newsize);这个函数第1个参数是原地址 第2个参数是新的大小 你可以输入一个数据判断一下是否到达内存大小的极限 到达了就重新分配附百度百科关于realloc的说明功能:先判断当前的指针是否有足够的连续空间,如果有,扩大mem_address指向的地址,并且将mem_address返回,如果空间不够,先按照newsize指定的大小分配空间,将原有数据从头到尾拷贝到新分配的内存区域,而后释放原来mem_address所指内存区域(注意:原来指针是自动释放,不需要使用free...
回复

使用道具 举报

千问 | 2013-7-31 11:52:24 | 显示全部楼层
很简单 的 我写过很多次了C动态读取文本内容首先打开文件 然后指针移动到最后 取返回值 得到文件字节长度。然后按这个长度malloc 一个动态数组文件指针移动到开始读取 存入动态数组...
回复

使用道具 举报

千问 | 2013-7-31 11:52:24 | 显示全部楼层
一般文件为了便于管理,需要先写个文件头,其中包含文件内容的数据,比如多少记录、数据量等。比如图象文件就要在文件头上记录图象尺寸、象素深度等信息。如果这个文件没有文件头,只有数据,只好根据记录格式逐一读入、可顺序申请内存存放,比如用链表形式存储,但需要确认内存是否能容纳全部数据,如果数据太多只好建立索引以便访问了。...
回复

使用道具 举报

千问 | 2013-7-31 11:52:24 | 显示全部楼层
先malloc数组然后按照需要realloc就行。...
回复

使用道具 举报

千问 | 2013-7-31 11:52:24 | 显示全部楼层
c用malloc,baidu一下你就知道,c++可以用容易,vector,list,deque...
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

主题

0

回帖

4882万

积分

论坛元老

Rank: 8Rank: 8

积分
48824836
热门排行