网站首页 > java教程 正文
数组是一类数据的集合,利用数组可以实现数据的存储,但如何实现数组?
一、利用结构体定义数据类型
数组是一种数据结构,需要利用结构体定义数据的类型,对于一个数组,需要知道数组的首元素的地址、数组长度、数组中的有效个数。
struct Arr{
int *pBase;//存储数组第一个元素的地址
int len;//存储数组最大元素个数
int cnt;//当前数组有效元素个数
};
二、数组初始化函数声明
定义结构体struct Arr,进行结构体变量声明
struct Arr arr;
在这个过程中,声明的结构体变量arr中的3个成员pBase、len、cnt存储的是内存中的垃圾值,需要对其进行初始化,定义初始化函数init_arr()。
需要考虑几个问题
(1)返回值。对于初始化,仅需要将结构体中各参数初始化不需要返回值,因此是void。
(2)参数。初始化函数中需要传入的参数。
首先考虑,如果传入的是结构体变量,相当于是将声明的结构体变量赋值给初始化函数,并不能修改主函数中结构体变量的各个成员的值,不能达到初始化的效果,因此需要传入的是结构体指针变量。
然后考虑,数组中的成员并不是不变的,因此初始化中可以传入数组的长度。
所以初始化的函数声明如下:
void init_arr(struct *pArr, int length);
三、数组初始化函数定义
函数定义是指函数需要实现的功能。数组初始化函数对数组分配内存、初始化数组长度以及初始化数组有效元素个数。
为数组分配内存,使用malloc()函数
pArr->pBase = (int *)malloc(sizeof(length) * length);
初始化数组的长度
pArr->len = length;
初始化数组有效个数
pArr->cnt = 0;
但在初始化过程中有可能出现内存分配失败的情况,因此采用if语句进行判断,判断malloc()函数返回值是否为空,具体代码如下
void init_arr(struct Arr *pArr, int length){
//为数组动态分配内存
pArr->pBase = (int *)malloc(sizeof(length) * length);
//返回空指针,结束函数
if(NULL == pArr->pBase){
printf("动态内存分配失败");
exit(-1);
}
else{
pArr->len = length;
pArr->cnt = 0;
}
return;
}
猜你喜欢
- 2024-10-23 运维--shell 中数组的操作(shell中数组如何定义)
- 2024-10-23 C/C++编程笔记:C 语言字符数组的定义与初始化,讲解到位
- 2024-10-23 Java SE之——数组 基础篇(java入门数组基础educoder)
- 2024-10-23 初识Java—(十)数组(1)(初识java)
- 2024-10-23 巧用C语言中数组部分元素初始化(c语言数组全部初始化为0)
- 2024-10-23 C语言数组算法实现_初始化(c语音数组初始化)
- 2024-10-23 北大学霸!手抄万字Java数组笔记,2小时吃透,你确定不拿走?
- 2024-10-23 C语言中的数组:声明、初始化和操作
- 2024-10-23 「C语言」初始化数组,C语言中初始化特定列表和元素
- 2024-10-23 C语言一维数组,如何初始化?有哪些方式?
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)